如何在 Laravel 迁移中设置默认时间戳和自动更新时间戳?

Susan Sarandon
发布: 2024-11-24 20:38:13
原创
905 人浏览过

How to Set Default Timestamps and Auto-Update Timestamps in Laravel Migrations?

将当前时间戳设置为 Laravel Migrations 中时间戳列的默认值

问:如何在 Laravel Migrations 中配置时间戳列默认为当前时间戳,并可选择根据值更新自身更改?

A: Laravel 的 Schema Builder 提供了一个简单的方法来实现此目的:

$table->timestamp('created_at')->default(DB::raw('CURRENT_TIMESTAMP'));
$table->timestamp('updated_at')->default(DB::raw('CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP'));
登录后复制

DB::raw 是用于创建原始表达式,允许我们将 CURRENT_TIMESTAMP 设置为 默认。该解决方案可以在各种数据库驱动程序中有效工作。

Laravel 中的增强功能:

  • useCurrent()(从 Laravel 5.1.25 开始提供) ): 将默认值设置简化为当前时间戳,替换DB::raw('CURRENT_TIMESTAMP').
$table->timestamp('created_at')->useCurrent();
登录后复制
  • useCurrentOnUpdate()(从 Laravel 8.36.0 开始提供):添加能够在值发生变化时更新时间戳useCurrent().
$table->timestamp('updated_at')->useCurrent()->useCurrentOnUpdate();
登录后复制

注意事项:

MySQL(5.7 及以上):

确保为时间戳列分配有效的默认值以避免潜在的问题无效日期的问题(例如 0000-00-00 00:00:00)。使用 useCurrent() 或使列可为空。

PostgreSQL 与 Laravel 4.x:

  • 时间戳列的默认精度可能会导致意外行为。
  • 使用CURRENT_TIMESTAMP(0) 或更新到 Laravel 5.0 以使用默认精度零并避免这些问题。

以上是如何在 Laravel 迁移中设置默认时间戳和自动更新时间戳?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板