你值得了解的8个Laravel模型时间戳使用小技巧(收藏)

下面由laravel教程栏目给大家分享8个laravel模型时间戳使用小技巧,看看你都没用过,没用就快来收藏吧,希望对大家有所帮助!

你值得了解的8个Laravel模型时间戳使用小技巧(收藏)

默认情况下,Laravel Eloquent 模型默认数据表有 created_at 和 updated_at 两个字段。当然,我们可以做很多自定义配置,实现很多有趣的功能。下面举例说明。

1、禁用时间戳

如果数据表没有这两个字段,保存数据时 Model::create($arrayOfValues); —— 会看到 SQL error。Laravel 在自动填充 created_at / updated_at 的时候,无法找到这两个字段。

禁用自动填充时间戳,只需要在 Eloquent Model 添加上一个属性:

class Role extends Model{  public $timestamps = FALSE;  // ... 其他的属性和方法}

2、修改时间戳默认列表

假如当前使用的是非 Laravel 类型的数据库,也就是你的时间戳列的命名方式与此不同该怎么办?也许,它们分别叫做 create_time 和 update_time。恭喜,你也可以在模型种这么定义:

class Role extends Model{  const CREATED_AT = 'create_time';  const UPDATED_AT = 'update_time'; }

3、修改时间戳日期 / 时间格式

以下内容引用官网文档 official Laravel documentation:

默认情况下,时间戳自动格式为 ‘Y-m-d H:i:s’。如果您需要自定义时间戳格式,可以在你的模型中设置 $dateFormat 属性。这个属性确定日期在数据库中的存储格式,以及在序列化成数组或 JSON 时的格式:

class Flight extends Model{  /**   * 日期时间的存储格式   *   * @var string   */  protected $dateFormat = 'U';}

4、多对多:带时间戳的中间表

当在多对多的关联中,时间戳不会自动填充,例如 用户表 users 和 角色表 roles 的中间表 role_user。

在这个模型中您可以这样定义关系:

class User extends Model{  public function roles()  {    return $this->belongsToMany(Role::class);  }}

然后当你想用户中添加角色时,可以这样使用:

$roleID = 1;$user->roles()->attach($roleID);

默认情况下,这个中间表不包含时间戳。并且 Laravel 不会尝试自动填充 created_at/updated_at
但是如果你想自动保存时间戳,您需要在迁移文件中添加 created_at/updated_at,然后在模型的关联中加上 ->withTimestamps();

public function roles(){  return $this->belongsToMany(Role::class)->withTimestamps();}

5、使用 latest() 和 oldest() 进行时间戳排序

使用时间戳排序有两个 “快捷方法”。

取而代之:

User::orderBy('created_at', 'desc')->get();

这么做更快捷:

User::latest()->get();

默认情况,latest() 使用 created_at 排序。

与之对应,有一个 oldest() ,将会这么排序 created_at ascending

巧文书 巧文书

巧文书是一款AI写标书、AI写方案的产品。通过自研的先进AI大模型,精准解析招标文件,智能生成投标内容。

巧文书 61 查看详情 巧文书

User::oldest()->get();

当然,也可以使用指定的其他字段排序。例如,如果想要使用 updated_at,可以这么做:

$lastUpdatedUser = User::latest('updated_at')->first();

6、不触发 updated_at 的修改

无论何时,当修改 Eloquent 记录,都将会自动使用当前时间戳来维护 updated_at 字段,这是个非常棒的特性。

但是有时候你却不想这么做,例如:当增加某个值,认为这不是 “整行更新”。

那么,你可以一切如上 —— 只需禁用 timestamps,记住这是临时的:

$user = User::find(1);$user->profile_views_count = 123;$user->timestamps = false;$user->save();复制代码

7、仅更新时间戳和关联时间戳

与上一个例子恰好相反,也许您需要仅更新 updated_at 字段,而不改变其他列。

所以,不建议下面这种写法:

$user->update(['updated_at' => now()]);

您可以使用更快捷的方法:

$user->touch();

另一种情况,有时候您不仅希望更新当前模型的 updated_at,也希望更新上级关系的记录。

例如,某个 comment 被更新,那么您希望将 post 表的 updated_at 也更新。

那么,您需要在模型中定义 $touches 属性:

class Comment extends Model {  protected $touches = ['post'];  public function post()  {    return $this->belongsTo('Post');  }}

8、时间戳字段自动转换 Carbon 类

最后一个技巧,但更像是一个提醒,因为您应该已经知道它。

默认情况下,created_at 和 updated_at 字段被自动转换为 $dates,

所以您不需要将他们转换为 Carbon 实例,即可以使用 Carbon 的方法。

例如:

$user->created_at->addDays(3);now()->diffInDays($user->updated_at);

更多编程相关知识,请访问:编程视频!!

以上就是你值得了解的8个Laravel模型时间戳使用小技巧(收藏)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/343546.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 19:24:44
下一篇 2025年11月5日 19:25:50

相关推荐

  • Laravel中富文本编辑器如何动态读取OSS配置信息?

    Laravel富文本编辑器与OSS配置的动态集成 在基于Laravel框架的SaaS应用中,使用富文本编辑器(例如UEditor)将内容上传到对象存储服务(OSS)时,需要动态读取OSS的访问密钥等配置信息。 直接将这些密钥硬编码到代码中并非最佳实践,尤其是在多租户环境下。 传统的做法是将配置信息写…

    2025年12月11日
    000
  • Laravel一对多关系查询:如何高效查找包含特定关键词文章的用户?

    Laravel一对多关联查询的挑战 在Laravel中,使用with()方法进行一对一关联查询非常简单。然而,当处理一对多关系时,with()方法可能会返回不符合预期结果的数据集。 例如,以下代码: User::with(‘posts’)->get(); 将返回所有用户及其所有关联的文章。但如…

    2025年12月11日
    000
  • Laravel 连表查询如何高效筛选关联数据?

    优化 Laravel 连表查询,高效筛选关联数据 Laravel 的 with() 方法方便进行连表查询,例如 User::with(‘post’)->get() 可以获取所有用户及其文章。但如果需要筛选特定条件下的关联数据,例如查找发表包含特定关键词文章的用户,with() 方法就显得力不从…

    2025年12月11日
    000
  • Laravel Eloquent关联查询:如何只获取拥有特定条件帖子的用户?

    掌握Laravel Eloquent关联查询技巧 Laravel Eloquent ORM在处理模型关联时,有时会遇到一些挑战。例如,如何高效地查询仅拥有符合特定条件帖子的用户? 直接使用User::with(‘posts’)这样的关联查询会返回所有用户,即使他们没有符合条件的帖子。 以下是如何只获…

    2025年12月11日
    000
  • MySQL订单主键出现间隔,如何有效解决?

    MySQL 订单主键跳号问题的有效解决方案 MySQL 数据库中,订单主键通常自增,但由于订单可能未支付而过期,导致主键出现跳号现象,影响数据库完整性和查询效率。 本文提供一种高效的解决方案:软删除。 什么是软删除? 软删除并非物理删除数据,而是通过添加一个标记字段(例如 deleted_at)来标…

    2025年12月11日
    000
  • 如何避免PHP-PDO操作MySQL时关键字冲突?

    巧妙规避PHP-PDO操作MySQL关键字冲突 在使用PHP-PDO操作MySQL数据库时,难免会遇到表名或字段名与MySQL关键字冲突的情况。这时,需要用反引号(`)将这些名称括起来。本文将探讨如何避免手动添加反引号的繁琐操作。 PDO的局限性 遗憾的是,PDO本身并不具备自动转义关键字的功能。P…

    2025年12月11日
    000
  • PHP新手如何搭建第一个原生网站?

    从零开始构建你的第一个PHP原生网站 对于PHP初学者来说,独立搭建网站可能让人望而却步。本指南将提供一个清晰的路径,助你顺利开启Web编程之旅。 学习资源推荐 为了快速上手,建议结合以下资源: 立即学习“PHP免费学习笔记(深入)”; 视频教程: 在B站搜索“ThinkPHP快速入门”,学习使用框…

    2025年12月11日
    000
  • PHP-PDO操作MySQL时如何处理关键字问题?

    巧妙应对PHP-PDO操作MySQL中的关键字冲突 在使用PHP-PDO操作MySQL数据库时,如果遇到表名或字段名与MySQL关键字冲突的情况,需要采取措施避免错误。 这篇文章将介绍如何有效处理这类问题。 解决方法 PHP-PDO本身并不提供自动处理关键字的功能。因此,我们通常采用以下两种方法: …

    2025年12月11日
    000
  • PHP-PDO操作MySQL时如何处理数据库关键字?

    巧妙应对PHP-PDO操作MySQL数据库关键字冲突 在使用PHP-PDO操作MySQL数据库时,经常会遇到表名或字段名与MySQL关键字冲突的问题。为了避免这类问题,通常需要使用反引号(`)将关键字括起来。那么,PHP-PDO是否提供自动处理关键字冲突的功能呢? 解决方法: 遗憾的是,PDO自身并…

    2025年12月11日
    000
  • Laravel项目中Nginx跨域配置失效:缺少always关键字如何解决?

    Nginx跨域配置失效:always关键字缺失的解决方案 在Laravel项目中进行跨域开发时,您可能遇到过这种情况:在Nginx中添加了跨域响应头,但接口响应中仍然缺少这些头信息。 问题分析及解决方法 您的Nginx配置可能类似如下: location / { add_header access-…

    2025年12月11日
    000
  • PHP语法基础到原生PHP网站开发:如何循序渐进地构建我的第一个网站?

    从PHP语法基础到原生PHP网站开发:循序渐进构建你的第一个网站 掌握PHP语法基础后,跃升至原生PHP网站开发是许多开发者的目标。然而,这需要清晰的规划和步骤。 学习资源:视频与代码示例 高效学习的关键在于结合视频教程和实际代码练习: 立即学习“PHP免费学习笔记(深入)”; 推荐视频教程: bi…

    2025年12月11日
    000
  • PHP-PDO操作MySQL时如何避免关键字冲突?

    巧妙规避PHP-PDO操作MySQL时关键字冲突 在使用PHP-PDO操作MySQL数据库时,如果表名或字段名与MySQL关键字冲突(例如user),就需要用反引号(` `)将其括起来。但PDO本身并不具备自动添加反引号的功能,这该如何解决呢? 主要有两种方法: 手动添加反引号: 在编写SQL语句时…

    2025年12月11日
    000
  • TP/Laravel框架哪个好用?后台开发推荐Laravel-Admin吗?

    TP与Laravel框架的选择难题 一位外包程序员寻求TP框架或Laravel框架的最佳选择建议。 Laravel-Admin:后台开发的理想之选 针对后台开发项目,我们推荐使用Laravel-Admin框架。其内置丰富的功能模块,可显著提升开发效率。主要功能包括: 用户账户管理菜单导航管理权限访问…

    2025年12月11日
    000
  • Laravel一主多从数据库配置:如何不使用常驻中间件实现读库负载均衡?

    Laravel 一主多从数据库配置与读库负载均衡 本文探讨如何在 Laravel 的一主多从数据库配置中,不依赖常驻中间件实现读库负载均衡。 挑战: Laravel 的一主多从架构,通常需要主库负责写入,从库负责读取。如何高效地将读请求分发到多个从库,避免单点压力,同时避免使用常驻中间件? 解决方案…

    2025年12月11日
    000
  • Laravel一主多从数据库:如何实现读库负载均衡?

    Laravel 一主多从数据库:高效读库负载均衡策略 Laravel框架简化了一主多从数据库的配置,实现读写分离,提升应用性能。所有写操作都定向主库,而读操作则分发到多个从库,有效降低主库压力。 Laravel 读库负载均衡的巧妙之处 不同于使用持久化中间件,Laravel在运行时动态选择从库连接,…

    2025年12月11日
    000
  • ThinkPHP与Laravel:哪个PHP框架更适合外包项目?

    ThinkPHP还是Laravel?外包项目的框架抉择 选择合适的PHP框架对成功的外包项目至关重要。ThinkPHP和Laravel都是流行选择,但哪一个更适合您的项目呢? ThinkPHP与Laravel的深入比较 ThinkPHP以其轻量级、高性能和灵活性而著称,提供ORM、MVC架构和模块化…

    2025年12月11日
    000
  • ThinkPHP还是Laravel?哪个PHP框架更适合我的外包项目?

    ThinkPHP与Laravel框架选型指南 最近承接了一个外包项目,需要选择合适的PHP框架进行开发。经过仔细评估,我将ThinkPHP (TP) 和Laravel作为主要候选框架进行对比分析,并给出最终的推荐意见。 Laravel框架: Laravel以其强大的功能和丰富的开箱即用特性而闻名。尤…

    2025年12月11日
    000
  • Laravel一主多从架构下如何实现读库负载均衡?

    Laravel 一主多从架构下的读库负载均衡实现 Laravel 的读写分离机制,主库负责写入,读操作则分布在多个从库上,有效缓解主库压力,提升系统性能。 不同于传统方案使用中间件拦截读请求,Laravel 的实现更简洁高效。读请求发出时,框架会随机选择一个可用的从库连接。无需中间件,开销极低。 要…

    2025年12月11日
    000
  • Composer 2.0安装Laravel失败怎么办?

    解决Composer 2.0无法安装Laravel的问题 使用Composer 2.0安装Laravel遇到问题?别担心,轻松几步就能解决! 全局安装Laravel安装器: 首先,你需要在你的系统上全局安装Laravel安装器。打开你的终端或命令提示符,运行以下命令: composer global…

    2025年12月11日
    000
  • Laravel Blade模板继承失效:子模板内容无法显示是什么原因?

    Laravel Blade模板继承故障排查 在Laravel框架中使用Blade模板引擎时,有时会遇到子模板内容无法正确显示的问题,导致模板继承失效。本文将分析可能的原因及解决方法。 问题现象: 子模板内容缺失或显示异常。模板继承路径已确认无误。@extends 和 @section 语法正确无误。…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信