繁体   English   中英

Laravel SQLSTATE [HY000]:常规错误:1364字段“ id”没有默认值

[英]Laravel SQLSTATE[HY000]: General error: 1364 Field 'id' doesn't have a default value

我现在在Laravel应用程序上工作了一段时间,但是当我现在运行php artisan migrate migration时,突然之间我总会收到错误消息:

SQLSTATE[HY000]: General error: 1364 Field 'id' doesn't have a default value (SQL: insert into `migrations` (`migration`, `batch`) values (2019_06_05_080701_create_departments_table, 22))

我不知道为什么会这样,因为以前从未发生过。 当我尝试迁移特定迁移时,会遇到相同的错误,那么这是怎么回事?

迁移如下所示:

public function up()
{
    Schema::create('departments', function (Blueprint $table) {
        $table->increments('id');
        $table->unsignedInteger('company_id');
        $table->string('name');
        $table->string('p_number')->nullable();
        $table->string('address')->nullable();
        $table->string('zipcode')->nullable();
        $table->string('city')->nullable();
        $table->string('contact_name')->nullable();
        $table->string('contact_email')->nullable();
        $table->string('contact_phone')->nullable();

        $table->timestamps();
    });
}

SHOW COLUMNS FROM migrations;结果SHOW COLUMNS FROM migrations;

在此处输入图片说明

触发此查询应适用于自动递增,这是id值未自动递增的原因

ALTER TABLE migrations MODIFY id INTEGER NOT NULL AUTO_INCREMENT;

注意:如果ID为0,则应将其更改为其他唯一ID值,然后通过查询获取ID的最大值,并将autoincrement设置为+1

SET @new_index = (SELECT MAX(id) FROM migrations );
SET @sql = CONCAT('ALTER TABLE migrations AUTO_INCREMENT = ', @new_index);
PREPARE st FROM @sql;
EXECUTE st;

参考

经过大量研究和良好答案,我找到了这个解决方案,它为我解决了:

ALTER TABLE migrations CHANGE COLUMN `id` `id` INT(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT = 123456;

该解决方案基于 ,从一个类似question-感谢答案@Dracula捕食者的很好的提示。

您一直收到此错误,因为您可能已修改了迁移表。 您可以尝试几种选择

  1. 运行php artisan migrate:fresh命令
  2. 删除所有表并重新运行所有迁移

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM