Laravel怎么在Model定义复合主键。
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Laravel怎么在Model定义复合主键。,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2167字,纯文字阅读大概需要4分钟。
内容图文
![Laravel怎么在Model定义复合主键。](/upload/InfoBanner/zyjiaocheng/240/7aae828ab7a840ceb8b666f67b7549c5.jpg)
REATE TABLE `carts` (
`user_id` int(10) unsigned NOT NULL,
`product_id` char(64) NOT NULL,
`quantity` int(10) unsigned NOT NULL,
`created_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
`updated_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
PRIMARY KEY (`user_id`,`product_id`),
KEY `fk_idx_cart_product` (`product_id`),
CONSTRAINT `fk_idx_cart_product` FOREIGN KEY (`product_id`) REFERENCES `products` (`id`),
CONSTRAINT `fk_idx_cart_user` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
需要用Eloquent ORM的save()方法,他会根据primaryKey来保存数据,请问如何在Model设置这种复合主键?
/**
* The primary key for the model.
*
* @var string
*/
protected $primaryKey = 'id';
$cart = Cart::firstOrNew([...]);
$cart->quantity = $quantity;
$cart->save();
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'id' in 'where clause'
回复内容:
表的结构如下:
REATE TABLE `carts` (
`user_id` int(10) unsigned NOT NULL,
`product_id` char(64) NOT NULL,
`quantity` int(10) unsigned NOT NULL,
`created_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
`updated_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
PRIMARY KEY (`user_id`,`product_id`),
KEY `fk_idx_cart_product` (`product_id`),
CONSTRAINT `fk_idx_cart_product` FOREIGN KEY (`product_id`) REFERENCES `products` (`id`),
CONSTRAINT `fk_idx_cart_user` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
需要用Eloquent ORM的save()方法,他会根据primaryKey来保存数据,请问如何在Model设置这种复合主键?
/**
* The primary key for the model.
*
* @var string
*/
protected $primaryKey = 'id';
$cart = Cart::firstOrNew([...]);
$cart->quantity = $quantity;
$cart->save();
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'id' in 'where clause'
这个问题没有解决,大部分别的框架也没有解决,所以暂时没有办法在Eloquent ORM 定义复合主键,解决办法:
1.使用doctrine。
2.在表单验证里面做验证,也能达到主键约束的效果。
关于这个问题其实在一年前就有国外的程序员在github上提了issue的,并且taylorotwell还参与了讨论,他给出的回复是laravel目前没有计划增加这个功能。直到今天(2015.11.07)都没有这个功能。详情请见以下链接:https://github.com/laravel/framework/issues/5355
内容总结
以上是互联网集市为您收集整理的Laravel怎么在Model定义复合主键。全部内容,希望文章能够帮你解决Laravel怎么在Model定义复合主键。所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。