设置外键时注意的小细节

今天在作业的时候,本以为在SQL中建表是很容易的一件事,可是在实际的设置外键方面还出现了一些小插曲,我们知道设置外键的命令格式为:

alter  table  <表名1>  add  constraint  <约束名>  foreign key (需要设置外键的列) references <表名2> (与外键关联的列);

如有两张表分别为:

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 , 就设置好外键了。

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


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值