设置外键的命令格式为:
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 , 就设置好外键了。
最后有一点小提示:在设置外键约束的时候,要保证外键字段的数据类型和大小(长度)要一样。