laravel数据库迁移int型数据该怎么写
laravel数据库迁移int型数据该怎么写
错误写法:
$table->engine = 'MyISAM'; $table->increments('id',11)->primary('id')->comment('主键自增id');//自增id $table->integer('dir_id',11)->comment('目录id');//目录id $table->integer('user_id',11)->comment('用户id');//用户id $table->string('name',255)->comment('素材名称');//素材名称 $table->string('path',255)->comment('素材路径');//素材路径
错误提示:
laravel数据库迁移中integer类型是无法指定长度的,很多小伙伴对integer类型传递第二个参数后会发现迁移报以错误
查看了错误提示后发现通过integer指定长度创建的子段自动添加了auto increament 以及 primary key 属性。
查看源代码后发现integer方法的第二个参数并不是指定长度,而是是否设置auto increment,所以integer方法无法指定子段长度,默认为11。
1 public function integer($column, $autoIncrement = false, $unsigned = false) 2 { 3 return $this->addColumn('integer', $column, 4 compact('autoIncrement', 'unsigned')); 5 }
所以正确写法:
1 $table->engine = 'MyISAM'; 2 $table->increments('id')->comment('主键自增id');//自增id 3 $table->integer('dir_id',false,false)->comment('目录id');//目录id 4 $table->integer('user_id',false,false)->comment('用户id');//用户id 5 $table->string('name',255)->comment('素材名称');//素材名称 6 $table->string('path',255)->comment('素材路径');//素材路径
然后可执行
# php artisan migrate
成功提示:
数据库生成如下:
如果需要修改字段,可以数据库回滚
# php artisan migrate:rollback