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

Laravel代码简洁之道和性能优化

经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...' ] ); 提供要作为第一个参数插入的值。...' => 'foo' , 'created_at' => now (), 'updated_at' => now ()], 'username' ); Eloquent 你可以在 Eloquent...当然了还是有一些注意点和坑,下面分享一下 注意的问题 要根据需求添加唯一索引 根据官方文档中的说明,我们的model中必须添加这行代码,才能以Eloquent的方式用 use \Staudenmeir\...LaravelUpsert\Eloquent\HasUpsertQueries; 因为我们数据库的时间是int类型,不是laravel默认的时间格式,并且我们的插入时间和更新时间也不是laravel默认的字段

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

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

    学习时间 只要成功安装了laravel的项目,已经内置了标准的carbon库文件,比如说在写入数据库字段 created_at 时是这样的格式: $item['created_at'] => "2020...在模型中添加以下声明: protected $casts = [ 'created_at' => 'datetime:Y-m-d', 'updated_at' => 'datetime:Y-m-d...或者在laravel5中使用 $dates 属性,功效与上面的方式相同: protected $dates = ['created_at', 'updated_at'] 读取的时候,该字段都会返回一个null...{ protected $dates = ['created_at', 'updated_at', 'deleted_at']; } 那么在使用的时候,手动自定义日期时间格式可使用链式操作: $user...接着使用Carbon对象的 format 方法,返回自定义的格式就可以了。

    3.6K20

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

    「ActiveRecord」是 ORM 的一种实现模式,Eloquent 则是 Laravel 版的「ActiveRecord」。...默认约定每张表都有 created_at 和 updated_at 字段(迁移类中 table->timestamps() 会生成这两个字段),并且在保存模型类时会自动维护这两个字段。...如果你的数据表里面不包含这两个字段,或者只包含一个,都需要设置 public $timestamps = false; 或者通过 CREATED_AT 和 UPDATED_AT 常量来设置自定义的创建和更新时间字段...: public const CREATED_AT = 'create_time'; public const UPDATED_AT = 'update_time'; 此外,默认时间的存储格式是 Y-m-d...时间戳: protected $dateFormat = 'U'; 这样,保存到数据库的时间格式就是 Unix 时间戳了,前提是你的 created_at 和 updated_at 字段是整型,否则会报格式错误

    8K20

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

    1、insert:插入数据时,需要维护 created_at 和 updated_at字段, 2、save:无论插入或者更新,会自动维护,无需手动操作 //插入: public function store...created_at 和 updated_at 时间戳随着 save 方法的调用,会自动维护,无需手动操作。 save 方法也可用于模型更新。...自动维护 created_at 和 updated_at两个字段 除了 save 和 saveMany 方法外,你还可以使用 create 方法。...还有, save 方法和 create 方法的不同之处在于, save 方法接受一个完整的 Eloquent 模型实例,而 create 则接受普通的 PHP 数组: $post = App\Post:...格式:create(【‘字段’=>值,组成的数组】); 参考连接: https://learnku.com/docs/laravel/5.6/eloquent-relationships/1404#3d967c

    1.9K10

    (转) Laravel Eloquent 提示和技巧

    原文:https://learnku.com/articles/19876#1face4 Eloquent ORM 看起来像一个简单的机制,但在幕后,有很多半隐藏的功能和不太知名的方法来实现更多。...', '>', '2018-11-11') ->orderByRaw('(updated_at - created_at) desc') ->get(); 14....命令行创建模型的同时,创建迁移文件和控制器 laravel创建模型的命令大家都很熟悉: php artisan make:model Company 不过你应该了解另外几个很常用的参数: php artisan...保存数据的同时 覆盖 updated_at 的默认更新时间 其实 ->save() 方法是可以接受额外参数的,因此,我们可以告诉它“忽略”updated_at默认功能以填充当前时间戳。...18. update() 方法的执行结果 你有没有想过这段代码究竟返回了什么?

    1.5K30

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

    默认情况下,Eloquent期望表中存在created_at和updated_at两个字段,字段类型为timestamp,如果不希望这两个字段的话,设置$timestamps为false eloquent ORM中,get和all方法查询出多个结果集,它们的返回值是一个Illuminate\Database\Eloquent\Collection对象,该对象提供了多种对结果集操作的方法...where('legs', '>', 100)->firstOrFail(); 如果没有捕获这个异常的话,laravel会自动返回给用户一个404的响应结果,因此如果希望找不到的时候返回404,是可以直接使用该方法返回的...,会自动为created_at和updated_at字段设置时间戳,不需要手动指定 批量赋值插入 使用create方法可以执行批量为模型的属性赋值的插入操作,该方法将会返回新插入的模型,在执行create...,设置模型属性为新的值,然后再save就可以更新了,updated_at字段会自动更新。

    85220

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

    说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...设计字段 按照上文提到的Category、Post、Comment和Tag之间的关系创建迁移Migration和模型Model,在项目根目录输入: php artisan make:model Category...function tags() { return $this->belongsToMany(Tag::class)->withTimestamps(); } } 根据迁移到库里的表生成字段属性和对应的方法提示...表的迁移Migration和关联Relationship都已设计好,测试数据也已经Seeder好了,就可以根据Repository模式来设计一些数据库逻辑了。...分享下最近发现的一张好图和一篇极赞的文章: 文章链接:Laravel的中大型專案架構

    3.6K42

    laravel 模型Eloquent ORM 添加编辑删除

    create 方法的返回值就是当前插入到数据库中的内容up可以通过返回值判断成功或者失败而实际开发中up经常需要返回新增数据的id那直接访问返回值的 id 属性即可。...$res = $TestMdl->where('id',$postId)->update($postData); dump($res); } update 方法的返回值是被改动的数据的条数...数据中一眼就发现了后三条数据的不同,我们之前用 DB 插入到数据库中的数据 created_at 和 updated_at 字段都是空,而我们用模型插入和修改后 created_at 和 updated_at...当时我希望能有一个恢复删除的功能比如说回收站,laravel 的模型为我们提供了很方便的软删除功能 要启用软删除首先数据表需要有 deleted_at 字段 之前玩迁移的时候简单的说了下创建迁移的时候调用...Laravel 的 数据库迁移 有创建这个字段的方法 现在,当你在模型实例上使用 delete 方法, 当前日期时间会写入 deleted_at 字段。

    1.7K21

    Laravel学习笔记(四)——模型,更安全的数据存取

    而在Laravel中的模型就相当于一个功能完善的数据库Helper类,不需要用户自己写,只要掌握基本用法就能很快速方便的对数据库进行操作,哪怕你一点不懂SQL语句。...看了接下来的Laravel模型的使用之后你就会爱上Laravel的Eloquent ORM模型,这也是我直接介绍模型而不讲解其他数据库操作的原因。...Eloquent ORM Laravel 的 Eloquent ORM 提供了漂亮、简洁的 ActiveRecord 实现来和数据库交互。每个数据库表都有一个对应的「模型」用来与该表交互。...false;//默认情况下,Eloquent 会默认数据表中存在 created_at 和 updated_at 这两个字段。...-- 用 -> 后面接属性名即可访问到对应的值 --> {{ $student -> info }} @stop 模型操作 获取对象后只需要简单的几行语句即可对数据库进行操作

    1.7K00

    Laravel学习笔记(四)——模型,更安全的数据存取

    而在Laravel中的模型就相当于一个功能完善的数据库Helper类,不需要用户自己写,只要掌握基本用法就能很快速方便的对数据库进行操作,哪怕你一点不懂SQL语句。...看了接下来的Laravel模型的使用之后你就会爱上Laravel的Eloquent ORM模型,这也是我直接介绍模型而不讲解其他数据库操作的原因。...Eloquent ORM Laravel 的 Eloquent ORM 提供了漂亮、简洁的 ActiveRecord 实现来和数据库交互。每个数据库表都有一个对应的「模型」用来与该表交互。...false;//默认情况下,Eloquent 会默认数据表中存在 created_at 和 updated_at 这两个字段。...-- 用 -> 后面接属性名即可访问到对应的值 --> {{ $student -> info }} @stop 模型操作 获取对象后只需要简单的几行语句即可对数据库进行操作

    2.1K00

    Laravel 模型操作中一次奇妙踩坑经历

    最近被 Laravel 模型中的一些小问题折腾的死去活来的,明明看着很清晰很明了的代码,却偏偏不能实现功能,现在带大家来切身经历一下这次奇妙的踩坑经历,代码看似很多,实则不多,大家别急着跑,哈哈。...返回的结果是修改了的.... 这就尴尬了,难道是对象集合中的非对象属性不能这样赋值?也不对呀,思来想去决定对对象本身做一个探索,直接在 map 中打印 $userTask : ?...明显看到 toArray 方法将 attributes 和 relations 转化成数组了,而且用的 array_merge 方法,大家知道相同 key 的时候,后面数组会覆盖前面数组,从前面的测试中可以看到...大公告成,可以说很优雅,哈哈,大家可能会问,你这直接返回了没有调用 toArray 啊,数据是怎么合并的怎么转换的?...特别鸣谢: zIym 同学[1] (咱俩一起跨的坑,哈哈) 结束语 其实吧最初我也没有想这么多,想了很多其它的解决办法,但是都是治根不治本,到头来发现自己对 Laravel 模型的工作原理还是不熟悉,只存在简单的应用上面

    1.6K30
    领券