使用seed 填充数据时 有遇到过 Incorrect datetime value 这种情况的吗?该怎么解决,

《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 5
德国科隆街头的大胡子
其他地方找的解决办法:

[SQL] Query web start

[ERR] 1292 - Incorrect datetime value: '0000-00-00 00:00:00' for column 's_playtime' at row 1

[ERR]

原因:mysql 的严格模式造成的,修改my.ini配置文件



解决方法:

修改my.ini配置文件,建议修改前新备份下,

my.ini中查找sql-mode,

我的MySQL版本为5.7.9,默认为:

sql-mode="STRICT_ALL_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ZERO_DATE,NO_ZERO_IN_DATE,NO_AUTO_CREATE_USER"NO_ZERO_DATE,NO_ZERO_IN_DATE,删掉保存重启mysql即可;

如果版本低的话默认可能是:

默认为sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",

将STRICT_TRANS_TABLES,删掉保存重启mysql即可;
4年前 评论

错误信息已经说的很清楚了,created_at 的值不对,传一个对的不就可以了?随便改一个试试

4年前 评论

@夜游人 这个值我没法控制哦。我是通过工厂文件生成数据的

file

4年前 评论
夜游人 4年前
$factory->define(User::class, function (Faker $faker) {
    $date_time = $faker->date . ' ' . $faker->time;
    return [
        'name' => $faker->name,
        'email' => $faker->unique()->safeEmail,
        'email_verified_at' => now(), 
        'activated' => true,
        'password' => bcrypt('123456'),
        'remember_token' => \Str::random(10),
        'created_at' => $date_time,
        'updated_at' => $date_time,
        'avatar' => $faker->image(storage_path('images'), 640, 360),
    ];    
});
4年前 评论

@夜游人

file会不会是数据库的原因 更新时间不能在创件时间之前

4年前 评论
夜游人 4年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!