一张数据表如何设置两个或多个外键?(已经更新了后续的问题,见链接)
目前后续的问题,已经更新,链接地址
我正在做商城数据表的设计,目前有一个商品表goods
、商品属性表attributes
、商品与属性关联表goods_and_attributes
:
如图所示,商品表已经与商品属性关联表有了联系,现在我想在商品属性关联表goods_and_attributes
中设置外键attribute_id
与商品属性表attributes
联系起来,数据库会报错:
我清空了数据,并且重新创建slq语句:
DROP TABLE IF EXISTS `goods_and_attribute`;
CREATE TABLE `goods_and_attribute` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`goods_id` int(11) DEFAULT NULL,
`value` varchar(50) NOT NULL,
`stock` int(11) NOT NULL,
`attribute_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `IDX_72C0A1A2B7683595` (`goods_id`),
KEY `IDX_20160603` (`attribute_id`) USING BTREE,
CONSTRAINT `FK_good_id_20160519` FOREIGN KEY (`goods_id`) REFERENCES `goods` (`id`)
CONSTRAINT `FK_attribute_id_20160603` FOREIGN KEY (`attribute_id`) REFERENCES `attributes` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
报错信息如下:
Error :
You have an error in your SQL syntax;
check the manual that corresponds to your MySQL server version
for the right syntax to use near 'CONSTRAINT `FK_attribute_id_20160519`
FOREIGN KEY (`attribute_id`) REFERENCES `a' at line 1
如果能给我一些建议,对我来说莫大的帮助!
回复内容:
目前后续的问题,已经更新,链接地址
我正在做商城数据表的设计,目前有一个商品表goods
、商品属性表attributes
、商品与属性关联表goods_and_attributes
:
如图所示,商品表已经与商品属性关联表有了联系,现在我想在商品属性关联表goods_and_attributes
中设置外键attribute_id
与商品属性表attributes
联系起来,数据库会报错:
我清空了数据,并且重新创建slq语句:
DROP TABLE IF EXISTS `goods_and_attribute`;
CREATE TABLE `goods_and_attribute` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`goods_id` int(11) DEFAULT NULL,
`value` varchar(50) NOT NULL,
`stock` int(11) NOT NULL,
`attribute_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `IDX_72C0A1A2B7683595` (`goods_id`),
KEY `IDX_20160603` (`attribute_id`) USING BTREE,
CONSTRAINT `FK_good_id_20160519` FOREIGN KEY (`goods_id`) REFERENCES `goods` (`id`)
CONSTRAINT `FK_attribute_id_20160603` FOREIGN KEY (`attribute_id`) REFERENCES `attributes` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
报错信息如下:
Error :
You have an error in your SQL syntax;
check the manual that corresponds to your MySQL server version
for the right syntax to use near 'CONSTRAINT `FK_attribute_id_20160519`
FOREIGN KEY (`attribute_id`) REFERENCES `a' at line 1
如果能给我一些建议,对我来说莫大的帮助!
不要用数据库的物理外键,用程序实现和维护逻辑外键,尤其是在高并发的互联网环境。
楼上正解.做物理外键是一种很不明智的选择.
我做过的工程从来都没做外键,这东西没什么意义啊,还有很多意外的影响,一般表做点索引就行了,还不是所有的情况都有,外键在大多数情况下,基本就是过度设计,没什么必要。你好好想想goods_and_attributes这表的设计更现实一些,当然你其他表设计的也。。。,创建者和日期,还有status或deteled都没有,你这也太简单了吧,像玩具啊,
上一篇: PHP和JS跳转
下一篇: 数据库左连接和右连接有什么区别