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

 

转载于:https://www.cnblogs.com/love-snow/articles/7340159.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值