Laravel 模型允许使用两个函数将值插入到数据库表中.他们是
Laravel Model allows two functions for inserting the values to the database table. They are
创建:User::create(['id'=>1,'name'=>'stack']);
插入:User::insert(['id'=>2,'name'=>'overflow']);
我发现它们执行类似的操作.它们有什么区别?
I found they perform similar operations. What's difference between them?
insert() :
如果你使用 insert() 方法,你不能默认 created_at 和 updated_at 数据库列它将为空
If you using insert() method you can't default created_at and updated_at database column it will be null
DefaultUser::insert(['username' => $request->username, 'city' => $request->city, 'profile_image' => $request->profile_image]);
<小时>
create() :当我们使用 create 方法时,您必须在 fillable fields
create() : when we use create method you must define this model in fillable fields
添加模型
protected $fillable = ['username','city', 'profile_image'];
添加控制器
DefaultUser::create(['username' => $request->username, 'city' => $request->city, 'profile_image' => $request->profile_image]);
那么我们就可以使用create方法而没有**mass assignment error **基本上在这里,表定义的字段在您的模型中受到保护
then we can use create method without **mass assignment error ** basically here , table defined fields are protected in your model
您应该定义要使质量可分配的模型属性.您可以使用模型上的 $fillable 属性来执行此操作
这篇关于Laravel 模型函数“create"和“create"有什么区别?和“插入"?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
MySQLi准备好的语句&foreach 循环MySQLi prepared statement amp; foreach loop(MySQLi准备好的语句amp;foreach 循环)
mysqli_insert_id() 是从整个服务器还是从同一用户获Is mysqli_insert_id() gets record from whole server or from same user?(mysqli_insert_id() 是从整个服务器还是从同一用户获取记录?)
PHP MySQLi 无法识别登录信息PHP MySQLi doesn#39;t recognize login info(PHP MySQLi 无法识别登录信息)
mysqli_select_db() 需要 2 个参数mysqli_select_db() expects exactly 2 parameters(mysqli_select_db() 需要 2 个参数)
Php mysql pdo 查询:用查询结果填充变量Php mysql pdo query: fill up variable with query result(Php mysql pdo 查询:用查询结果填充变量)
MySQLI 28000/1045 用户“root"@“localhost"的访问MySQLI 28000/1045 Access denied for user #39;root#39;@#39;localhost#39;(MySQLI 28000/1045 用户“root@“localhost的访问被拒绝)