Laravel 5 Migration,整数

时间:2015-05-19 14:35:54

标签: php migration schema laravel-5 builder

我试图创建一个以 0 作为默认整数值的表格 代码如下:

Schema::create('gsd_proyecto', function($table) {
        $table->increments('id');
        $table->string('nombre', 80)->unique();
        $table->string('descripcion', 250)->nullable();
        $table->date('fechaInicio')->nullable();
        $table->date('fechaFin')->nullable();
        $table->integer('estado', 1)->default(0);
        $table->string('ultimoModifico', 35)->nullable();
        $table->timestamps();
    });

但是当我运行迁移时,我收到了下一个错误:

Next exception 'Illuminate\Database\QueryException' with message 'SQLSTATE[42000]: Syntax error or access violation: 1067 Invalid default value for 'estado' 

我正在检查laravel创建的SQL是什么,我找到了

create table `gsd_proyecto` (
 `id` int unsigned not null auto_increment primary key, 
 `nombre` varchar(80) not null, 
 `descripcion` varchar(250) null, 
 `fechaInicio` date null, 
 `fechaFin` date null, 
 `estado` int not null default '0' auto_increment primary key,   
 `ultimoModifico` varchar(35) null, 
 `created_at` timestamp default 0 not null, 
 `updated_at` timestamp default 0 not null
)

正如您所看到的,laravel正在尝试使用char值('0')设置字段 estado ,并将其设置为自动增量主键

任何帮助都将非常感激

1 个答案:

答案 0 :(得分:14)

删除integer方法中的第二个参数。它将列设置为自动增量。检查Laravel API以获取更多详细信息。

http://laravel.com/api/5.0/Illuminate/Database/Schema/Blueprint.html#method_integer

$table->integer('estado')->default(0);