Миграция на Laravel 5, невалидна стойност по подразбиране, когато е цяло число

Опитвах се да създам таблица с 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' 

Проверявах какъв е SQL, създаден от laravel, и намерих следващия

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 се опитва да зададе полето estado със стойност char ('0'), а също и като първичен ключ за автоматично нарастване

Всяка помощ ще бъде наистина оценена


person WindSaber    schedule 19.05.2015    source източник


Отговори (1)


Премахнете втория параметър в метода integer. Той задава колоната като автоматично нарастване. Проверете API на Laravel за повече подробности.

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

$table->integer('estado')->default(0);
person Yasen Zhelev    schedule 19.05.2015
comment
Проработи! Благодаря много! Мислех си в дефиниция като MySql... вместо това сега използвам tinyInteger и сега работи. Благодаря много! - person WindSaber; 19.05.2015