【laravel避坑笔记】laravel报错的问题42S01 420004 42S22]等…

2022-05-15 0 616

下面由Laravel教程栏目给大家介绍laravel报错的问题42S01 420004 42S22]等… 希望对需要的朋友有所帮助!

laravel避坑笔记

来源网络

1.Laravel 5.4: Specified key was too long error

原因:从LV 5.4起数据库默认字符集为utf8mb4(包括了对 emojis 的支持)。如果使用的是 MySQL v5.7.7 或更高版本不需要做什么修改。
使用更早版本的MySQL数据库(包括MariaDB)的童鞋可以这样修改了,修改文件 /project/app/Providers/AppServiceProvider.php

use Illuminate\\Support\\Facades\\Schema; // 注意要引入命名空间 public function boot()    {        Schema::defaultStringLength(191); // 针对 早期 mysql 数据迁移    }

再重新使用迁移命令:

php artisan migrate

2.SQLSTATE[42S01]: Base table or view already exists: 1050

迁移数据时表已存在,

解决办法:

删除已存在的表,然后重新迁移。

3.PDOException::(“SQLSTATE[42000]: Syntax error or access violation: 1067 Invalid default value for ‘published_at’”)

修改方法一:vim config/database.php

'mysql' => [     'driver' => 'mysql',.... ...     'prefix' => '',      'strict' => true, // 修改这里     'engine' => null, ],

修改为:

'mysql' => [     'driver' => 'mysql',.... ...     'prefix' => '',      'strict' => false, // 修改这里     'engine' => null, ],

设置可为空的时间戳:

$table->nullableTimestamps()

设置默认时间戳

$table->timestamps('created_at');// 会生成created_at\\updated_at字段

4.PDOException::(“SQLSTATE[42S22]: Column not found: 1054 Unknown column ‘created_at’ in ‘field list’”)

此问题是由于 table 迁移时没有设置默认时间戳字段,但使用的是 factory 方法 生成 seed 数据,可以修改

public function up()    {         Schema::create('posts', function (Blueprint $table) {      $table->increments('id');      $table->string('slug')->unique();      $table->string('title');      $table->text('content');      $table->timestamps(); // 添加这行      }); }

重复make:migration

确切来说,这个也不算是坑,因为这个操作本身就是只需执行一次

但对于新手来说,可能无意间就重复执行多次,而 make:migration 时是不会报错的;
而在执行迁移时问题就来了:

【laravel避坑笔记】laravel报错的问题42S01 420004 42S22]等…

解决办法就是删除或修改同一 table 的 schema 名称。
【laravel避坑笔记】laravel报错的问题42S01 420004 42S22]等…

5.php artisan db:seed 表名变复数 单数

这可能和 Chinglish 有关,老外习惯把表名写为复数,所以干脆默认Model 对应的表名是这个英文单词的复数形式
因此,要在 model 里重写 $table 属性,如:

protected $table=’student’;

查找于网络,储存方便自己方便他人

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

【声明:根据2013年1月30日《计算机软件保护条例》2次修订第17条规定: 为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存 储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬! 鉴于此,也希望大家按此说明研究软件!】
本站所有源码尽量保证原汁原味,如有特殊情况会作出声明及标注,网站资源不做任何二次加密(原版加密除外,不影响程序使用的不会做解密处理),方便您更好的学习参考。 在您的能力范围内,为了大环境的良性发展,请尽可能的选择正版资源。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

即刻码站__国内靠谱的站长资源下载平台 php教程 【laravel避坑笔记】laravel报错的问题42S01 420004 42S22]等… https://www.jike1995.com/36346.html

常见问题
  • 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度
查看详情

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务