[英]updateOrCreate cause ErrorException in laravel
I wrote a code to login or register users.I used updateOrCreate function to add user if not exist an update a column that is name is verifcode if user exist 我编写了用于登录或注册用户的代码。我使用updateOrCreate函数添加用户(如果不存在),如果用户存在,则更新名为verifcode的列
controller 控制者
users Table:
id(auto increment primary key)|phone|verifcode|timeStmp
---------------------------------
$phone=Input::get('phone');
$code=rand(1001,9999);
$user = new user;
$user = array('phone'=>$phone);
user::updateOrCreate($user,['verifcode' => $code]);
Model: 模型:
namespace App;
use Illuminate\Database\Eloquent\Model;
class user extends Model
{
protected $table = 'users';
protected $fillable = array('phone', 'verifcode','timeStmp');
protected $guarded = array('id');
protected $primaryKey = "id";
public $incrementing = false;
const CREATED_AT= false;
const UPDATED_AT = false;
}
with this code i have folowing error: array_key_exists(): The first argument should be either a string or an integer
that point to vendor\\laravel\\framework\\src\\Illuminate\\Database\\Eloquent\\Concerns\\HasAttributes.php
file. 与此代码,我有以下错误: array_key_exists(): The first argument should be either a string or an integer
指向vendor\\laravel\\framework\\src\\Illuminate\\Database\\Eloquent\\Concerns\\HasAttributes.php
文件array_key_exists(): The first argument should be either a string or an integer
。
i just know that error point to secound argument of UpdateOrCreate function. 我只知道错误指向UpdateOrCreate函数的secound参数。
thanks for help 感谢帮助
If you take a look at the Laravel documentation , you're just using the updateOrCreate
method wrong. 如果看一下Laravel文档 ,您只是在使用updateOrCreate
方法错误。 Look at the flight example there. 看那里的航班示例。
In your case it should look like this: 在您的情况下,它应如下所示:
$phone = \Input::get('phone')
$code = rand(1001, 9999);
$user = User::updateOrCreate(
['phone' => $phone],
['verifcode' => $code, 'timeStmp' => \Carbon::now()->timestamp]
);
If you see at the Model
class of laravel framework code, you can note, that updated_at
is stored only when it is not dirty
. 如果您在laravel框架代码的Model
类中看到,您会注意到, updated_at
仅在不dirty
时存储。
if (! $this->isDirty(static::UPDATED_AT)) {
$this->setUpdatedAt($time);
}
But isDirty
method checks for nulls only. 但是isDirty
方法仅检查null。
public function isDirty($attributes = null)
{
$dirty = $this->getDirty();
if (is_null($attributes)) {
return count($dirty) > 0;
}
if (! is_array($attributes)) {
$attributes = func_get_args();
}
foreach ($attributes as $attribute) {
if (array_key_exists($attribute, $dirty)) {
return true;
}
}
return false;
}
So just substitute false
with NULL
. 因此,只需将false
替换为NULL
。
$phone=Input::get('phone');
$code=rand(1001,9999);
user::updateOrCreate(
['phone' => $phone]
['verifcode' => $code]
);
See if it is work for you. 看看是否适合您。
finally i solve it. 终于我解决了。 by adding Created_at and Update_at columns to table and adding this two coulmn to $guarded in model like this protected $guarded = array('id','CREATED_AT','UPDATED_AT');
通过向表中添加Created_at和Update_at列,并将这两个同伴添加到$ guarded的模型中,例如: protected $guarded = array('id','CREATED_AT','UPDATED_AT');
and then problem fixed 然后解决问题
thanks for help 感谢帮助
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.