数据库
首页 > 数据库> > mysql-如何避免添加重复的外键约束

mysql-如何避免添加重复的外键约束

作者:互联网

我想知道是否可以避免多次添加相同的外键约束?

例如:如果我执行下面的查询3次,则在phpmyadmin中约束将存在3次…我第二次和第三次应用该查询都会被拒绝,这将是非常棒的.

ALTER TABLE `my_items_details`
ADD FOREIGN KEY (`items_id`) REFERENCES `my_items`(`item_id`)
ON DELETE RESTRICT
ON UPDATE CASCADE;

解决方法:

您可以给外键指定一个明确的名称,而不是让MySQL为您分配默认名称.

ALTER TABLE `my_items_details`
ADD FOREIGN KEY  `my_foreign_key`  (`item_id`) REFERENCES `my_items`(`item_id`)
ON DELETE RESTRICT
ON UPDATE CASCADE;

由于两个相同类型的对象不能具有相同的名称,因此该查询将在您第二次运行它时生成错误:

Error: ER_FK_DUP_NAME: Duplicate foreign key constraint name ‘my_foreign_key’

Demo on DB Fiddle

标签:foreign-keys,sql,mysql
来源: https://codeday.me/bug/20191211/2105846.html