首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

laravel insert 、save、update、create区别(总结二)

1、insert:插入数据时,需要维护 created_at 和 updated_at字段, 2、save:无论插入或者更新,会自动维护,无需手动操作 //插入: public function store...created_at 和 updated_at 时间戳随着 save 方法的调用,会自动维护,无需手动操作。 save 方法也可用于模型更新。...同样地,updated_at 时间戳自动更新,无需手动操作: 3.update:更新操作,自动维护 updated_at字段 也可一并更新查询到的多个模型。...自动维护 created_at 和 updated_at两个字段 除了 save 和 saveMany 方法外,你还可以使用 create 方法。...格式:create(【‘字段’=>值,组成的数组】); 参考连接: https://learnku.com/docs/laravel/5.6/eloquent-relationships/1404#3d967c

1.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【译】20个 Laravel Eloquent 小技巧(下)

    继续介绍 Laravel Eloquent 的小技巧 11....自定义属性排序 假设你有下面的一段代码: (设定了一个在返回对象时候的附加属性 ‘full_name’参见 tips5 模型属性: 时间戳, 附加属性(appends) 等) function getFullNameAttribute...在保存的时候重写 update_at 字段 你知道 - > save()方法是可以接受参数的吗? 因此,我们可以告诉它“忽略” updated_at默认填充当前时间戳的功能。...Laravel 默认会给所有实体类配置时间戳,如果不需要一般是在模型中指定 $timestamps = false 18. update()方法的返回值是什么?...$result = $products->whereNull('category_id')->update(['category_id' => 2]); 我的意思是,更新语句是在数据库中正确执行的,但

    2.8K10

    通过 Laravel Eloquent 模型实现简单增删改查操作

    Eloquent 默认约定每张表都有 created_at 和 updated_at 字段(迁移类中 table->timestamps() 会生成这两个字段),并且在保存模型类时会自动维护这两个字段...如果你的数据表里面不包含这两个字段,或者只包含一个,都需要设置 public $timestamps = false; 或者通过 CREATED_AT 和 UPDATED_AT 常量来设置自定义的创建和更新时间字段...H:i:s,你还可以通过 $dateFormat 属性来自定义时间戳的格式,该属性值通过 PHP 的 date() 函数进行解析,所以原则上支持 date 函数支持的所有语法格式,比如将时间设置为 Unix...时间戳: protected $dateFormat = 'U'; 这样,保存到数据库的时间格式就是 Unix 时间戳了,前提是你的 created_at 和 updated_at 字段是整型,否则会报格式错误...App\Post; $post->title = '测试文章标题'; $post->content = '测试文章内容'; $post->user_id = 1; $post->save(); 创建时间和更新时间字段由

    8K20

    3分钟短文:Laravel模型创建数据条目的2个语法糖

    [img] 本期我们开始讲模型中,如何插入新条目,或者更新既有条目。...代码时间 我们在构建一个hello world页面的时候,已经介绍了如何使用laravel的命令行脚手架创建新的模型文件,以及通过迁移功能创建数据库表。这样就把数据操作衔接起来了。...原有如下: id字段是 auto_increment 约束,自动递增; created_at / updated_at 字段,在Event模型内使用了 $timestamp = true。...这样laravel在处理模型数据的时候,会默认更新此二字段。 然而,对于写入数据库的那些数据,并不是所有字段都会允许写入的。在模型内我们可以手动指定哪些字段可以写,哪些字段不可以写。...新建 or 更新 接着介绍laravel模型的几个语法糖。一个常规的场景,比如在写入数据时,先判断数据库表内是否有该条记录,如果没有就创建,如何有则返回。

    1.9K00

    3分钟短文:Laravel Carbon自定义日期时间格式

    引言 laravel引用了强大的Carbon日期时间处理库用于日期时间的操作, 并且在数据库的格式化中使用该库。本文就说一说程序中如何方便地使用 Carbon自定义格式。...学习时间 只要成功安装了laravel的项目,已经内置了标准的carbon库文件,比如说在写入数据库字段 created_at 时是这样的格式: $item['created_at'] => "2020...比如说有比较特殊的地区日期格式,就可以使用标准字符串定义: $suborder['payment_date'] = $createdAt->format('M d Y'); 随着laravel的版本更新升级...或者在laravel5中使用 $dates 属性,功效与上面的方式相同: protected $dates = ['created_at', 'updated_at'] 读取的时候,该字段都会返回一个null...在模板中打印默认格式的日期时间字符串,可以这样使用: {{$user->created_at->toFormattedDateString()}} 写在最后 本文介绍了laravel模型中的 $casts

    3.6K20

    Laravel迁移数据库!

    比如主键默认的自增 id,还有用于记录创建时间 created_at 和 更新时间 updated_at,一个 timestamps() 方法就包含了, 只不过默认使用的是不直观的整型时间戳,如果要使用...datetime 格式用于直观地读取,则可以手动声明: $table->dateTime('created_at')->comment('创建时间'); $table->dateTime('updated_at...')->comment('更新时间'); 与创建表方法对应的是回滚时候的删除表,下面是默认的 down 方法: public function down() { Schema::drop('users...自力更生 那么,上面的是系统自带的迁移文件,开发者如何自己手动生成呢?...写在最后 本文介绍了laravel中使用迁移功能操作数据库的创建,修改,移除字段,删除表等,把开发者从手动维护数据库的状态中解脱出来。这样也为团队协作时的有章可循做了铺垫。

    98610

    Laravel迁移数据库!

    比如主键默认的自增 id,还有用于记录创建时间 created_at 和 更新时间 updated_at,一个 timestamps() 方法就包含了, 只不过默认使用的是不直观的整型时间戳,如果要使用...datetime 格式用于直观地读取,则可以手动声明: $table->dateTime('created_at')->comment('创建时间'); $table->dateTime('updated_at...')->comment('更新时间'); 与创建表方法对应的是回滚时候的删除表,下面是默认的 down 方法: public function down() { Schema::drop('users...自力更生 那么,上面的是系统自带的迁移文件,开发者如何自己手动生成呢?...写在最后 本文介绍了laravel中使用迁移功能操作数据库的创建,修改,移除字段,删除表等,把开发者从手动维护数据库的状态中解脱出来。这样也为团队协作时的有章可循做了铺垫。

    1.1K00

    【译】20个 Laravel Eloquent 小技巧(上)

    下面是翻译自 Laravel-News 的一篇教程,总结了 Laravel 的对象关系映射框架(ORM)的几个小技巧。...模型属性: 时间戳, 附加属性(appends) 等 Eloquent模型有一些“参数”,会以该类的属性形式出现。...create 方法中直接创建 protected $dates = ['created_at', 'deleted_at']; // 这些字段将会转换成 Carbon类型的,可以方便的使用 Carbon...= 'updated_at'; // 默认的时间戳字段也是可以改变的 public $timestamps = false; // 或者完全不用他 甚至还有更多,我仅仅列出了最有意思的一部分,更多请查看默认抽象...使用关系模型字段排序 一个更复杂的“技巧”。 如果你有帖子,但要通过最新帖子对它们进行排序? 顶部有最新更新主题的论坛中非常常见的要求,对吧?

    2.2K50

    Laravel API教程:如何构建和测试RESTful API

    在本文中,我们将探讨如何构建和测试使用Laravel进行身份验证的强大API。我们将使用Laravel 5.4,所有的代码都可以在GitHub上参考。...更新动作:PUT vs POST RESTful API中有很多争论的问题,对于使用POST,PATCH或者PUT更新哪个是最好的,或者创建动作最好留给PUT动词这种问题有很多的意见。...在本文中,我们将使用PUT更新操作,根据HTTP RFC,,PUT意味着在特定位置创建/更新资源。...最后,您将以适合您的应用程序的方式来决定如何构建资源和模型。 关于一致性的说明 使用一组约定(如REST)的最大优点是您的API将更容易消费和开发。...$table->timestamps() 将会为我们生成时间戳——在created_at和updated_at时,但是不用担心设置一个默认的,Laravel将在需要时更新这些字段。

    20.4K20

    【Mysql】Working with time zones...

    关于时间戳、日期和时区的真正工作原理,似乎存在不少困惑。本文旨在揭开这些概念的神秘面纱,并就如何在 Laravel 应用程序和 MySQL 中以合理的方式处理日期和时区给出一些建议和最佳实践。...现在,让我们用具体的日期和时间举几个例子,看看时间戳的存储和检索在实际生活中是如何工作的。...Let’s now see how dates and times are handled by Laravel. 我们已经了解了 MySQL 如何处理时间戳。...现在让我们看看 Laravel 是如何处理日期和时间的。...如果没有特别设置,数据库可能会使用运行服务器的系统时间。 我们在 Laravel 应用程序中使用 now() 辅助函数生成一个日期,返回如下日期:"2023-10-13 16:00:00"。

    17730

    跟我一起学Laravel-EloquentORM基础部分

    默认情况下,Eloquent期望表中存在created_at和updated_at两个字段,字段类型为timestamp,如果不希望这两个字段的话,设置$timestamps为false 字段设置时间戳,不需要手动指定 批量赋值插入 使用create方法可以执行批量为模型的属性赋值的插入操作,该方法将会返回新插入的模型,在执行create方法之前,需要先在模型中指定fillable和guarded...$flight = App\Flight::firstOrNew(['name' => 'Flight 10']); 更新 基本更新操作 方法save不仅可以要用来插入新的数据,也可以用来更新数据,只需先使用模型方法查询出要更新的数据...,设置模型属性为新的值,然后再save就可以更新了,updated_at字段会自动更新。...,而是设置该字段的时间戳,由Eloquent模型屏蔽已经设置该字段的数据。

    85220

    3分钟短文:Laravel模型读数据的那个“障眼法”

    laravel模型的精巧设计使得我们操作数据层逻辑更加得心应手。 [图片] 本文我们来说说模型在读写数据中所使用的技巧。...日期时间格式化 先从最常用的地方着手,比如在迁移文件内使用的 timestamps方法,就是在表内生成 created_at和updated_at两个 datetime 类型的字段,用于标记该记录的创建时间和更新时间...laravel框架继承了广泛使用稳定可靠的 Carbon 类库用于操作日期时间。...= ['created_at','updated_at','started_at']; 那么这三个字段都会使用 Carbon 进行格式化,在访问模型对象属性时,就会返回该Carbon对象。...这是laravel提供的语法糖,很好使! 写在最后 本文通过日期时间字段的格式化方法,引申出laravel模型的访问器功能,并通过实例介绍了具体的用法。

    94011

    Laravel5.2之Seeder填充数据小技巧

    说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...开发环境:Laravel5.2 + MAMP + PHP7 + MySQL5.5 开发插件三件套 在先聊测试数据填充器seeder之前,先装上开发插件三件套,开发神器。先不管这能干些啥,装上再说。...1、barryvdh/laravel-debugbar composer require barryvdh/laravel-debugbar --dev 2、barryvdh/laravel-ide-helper...,在控制器里输入方法时会自动补全auto complete字段属性的方法: 2、mpociot/laravel-test-factory-helper 输入指令php artisan test-factory-helper...Laravel官方推荐使用模型工厂自动生成测试数据,推荐这么写的: //先输入指令生成database/seeds/CategoryTableSeeder.php文件: php artisan make

    3.6K42

    Go Mongox:轻松实现 MongoDB 时间字段自动填充

    前言在 MongoDB 的集合中,时间字段(如 创建时间 和 更新时间)通常是必不可少的。在使用 Go 语言操作 MongoDB 时,例如执行插入或更新操作,我们需要手动设置这些时间字段的值。...本文将介绍如何使用 mongox 库,在插入和更新数据时自动填充时间字段,从而提升开发效率并减少重复代码。...使用秒级时间戳填充字段 CreateMilliTime int64 `bson:"create_milli_time" mongox:"autoCreateTime:milli"` // 使用毫秒级时间戳填充字段...fmt.Println 语句都输出 true,说明更新时间字段的值都已更新。...fmt.Println 语句都输出 true,说明所有时间字段的值都被填充。小结本文详细介绍了如何使用 mongox 库,在插入和更新数据时自动填充时间字段。

    3491110
    领券