自定义主键后,需要注意的地方
订单Order模型覆盖主键后
protected $primaryKey = 'no';
关联模型OrderItem保存数据时报错(该模型主键获取到的是Order模型id主键数据,非定义的no字段的数据)
操作一:删除设置的覆盖主键
protected $primaryKey = 'no';
设置关联如下,提交数据正常
public function items() {
return $this->hasMany(OrderItem::class,'order_id','no');
}
无奈,重读 快速入门《Laravel 5.6 中文文档》 Eloquent 模型约定--主键 部分
使用非递增或者非数字的主键,则必须在模型上设置 public $incrementing = false 。
最后在原基础上加一句,解决问题。
protected $primaryKey = 'no';
public $incrementing = false;//加上这句
知识点:
非递增或者非数字的主键,需要加上
public $incrementing = false;
非整数主键,需要加上
protected $keyType = string;
本作品采用《CC 协议》,转载必须注明作者和本文链接
题外话,主键还是使用id且自增int为好。
如有需要可以定义order_number或者number存储订单号。
不是很推荐用order_no. 这样的缩写。因为number标准的缩写是No. 并不适合编程命名
@Max 个人见解,主键不使用自增是防猜单,小白入门学习折腾中
@zoang 是的,所以可以过滤掉id,而使用number来进行检索order模型。 但是order_item中依旧使用order_id来关联order表的id。
@Max 明白你的意思,哈
protected $keyType = string; 写法错的,
protected $keyType = 'string';
字符串类型的自定义主键值,在添加数据的时候应该怎么添加自定义的主键值?在laravel_admin创建添加页面时,id是不会显示id这个字段的