php - Laravel 时间戳显示毫秒

标签 php mysql laravel laravel-5

我需要在 Laravel 应用程序上高精度地存储 updated_at 时间戳,使用格式 "m-d-Y H:i:s.u"(包括毫秒)

根据 laravel 文档,我可以通过在类上设置 $dateFormat 属性来自定义日期格式,但是...

主要问题是 Laravel 的模式构建器在我使用 $table->nullableTimestamps() 时在数据库中添加了一个时间戳类型的列,并且根据 mysql 文档,TIMESTAMP 类型的列只允许精确到秒..

关于如何实现这一点有什么想法吗?

最佳答案

你不能,因为 PHP PDO 驱动程序不支持时间戳中的小数秒。解决方法是选择时间戳作为字符串,这样 PDO 驱动程序就不知道它真的是时间戳,只需执行 $query->selectRaw(DB::raw("CONCAT(my_date_column) as my_date_column")) 但是这意味着您不能对所有字段使用默认选择,因此查询变得非常痛苦。您还需要覆盖模型上的 getDateFormat。

// override to include micro seconds when dates are put into mysql.
protected function getDateFormat()
{
    return 'Y-m-d H:i:s.u';
}

最后在您的迁移而不是 nullableTimestamps 中,在 Schema 回调之外执行:

DB::statement("ALTER TABLE `$tableName` ADD COLUMN created_at TIMESTAMP(3) NULL");

请注意,此示例适用于 3 位小数,但如果您愿意,您最多可以有 6 位小数,方法是在 alter table 和 sprintf 中的两个位置将 3 更改为 6,并将乘数 * 1000 调整为 1000000 6.

希望有一天 PHP PDO 会更新以解决此问题,但它已经 5 年多了,什么都没有改变,所以我不抱希望了。如果您对详细信息感兴趣,请参阅此错误报告: http://grokbase.com/t/php/php-bugs/11524dvh68/php-bug-bug-54648-new-pdo-forces-format-of-datetime-fields 我在另一个答案中找到了该链接,这可能有助于您更好地理解该问题: https://stackoverflow.com/a/22990991/259521

PHP 最近真的很老了,我认为这个问题是我考虑转向更现代的 Node.js 的原因之一。

关于php - Laravel 时间戳显示毫秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31227069/

相关文章:

php - Laravel: 类 App\Posts 不存在

javascript - formData 的参数之一可以包含对象吗?

php - 如何在 for 循环中循环以获取具有相同 ID 的多个值

Javascript 不响应点击事件 [Laravel 5.5]

javascript - 如何在不刷新的情况下将 JavaScript/Ajax 中的选择值解析为 PHP

php - 如何使用 php graph Api 保存 facebook 个人资料图片

mysql - Oracle - 返回具有 max_date 重复项的行

mysql - 如何将 2 个不同的列分组在一起

php - 获取 UTF-8 字符串的第一个字符

php - 如何将新的 paypal sdk 添加到 php 中已存在的另一个 paypal sdk 的文件 autoload.php