mysql 外键设置需要注意什么意思_mysql 设置外键时注意的小细节

设置外键的命令格式为:

alter  table    add  constraint    foreign key (需要设置外键的列) references  (与外键关联的列);

如有两张表分别为:

create table actor

(

id integer primary key not null,

name char(36) ,          --需要设置为唯一键 否则无法成功设置外键

)

create table casting

(

movieid varchar(70)  not null,

actorid char(36) not null,

ord integer,

primary key(movieid,actorid)            --设置复合主键

)

alter table casting add constraint cas_actorid_actor foreign key (actorid) references actor (name)  --设置外键的命令(actorid是外键,指向actor表中的对应的演员)

如果像上面这样来设置外键,将会出错:

服务器: 消息 1776,级别 16,状态 1,行 1

在被引用表 'actor' 中没有与外键 'cas_actorid_actor' 的引用列的列表匹配的主键或候选键。

服务器: 消息 1750,级别 16,状态 1,行 1

未能创建约束。请参阅前面的错误信息。

解决方案:这个原因是由于actor表被引用的的字段不是候选键或者不是主键,说白了就是确保它是唯一的;因此只需要在actor表中的name字段后面添加unique就可以了,即改成name char(36)unique , 就设置好外键了。

最后有一点小提示:在设置外键约束的时候,要保证外键字段的数据类型和大小(长度)要一样。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值