sql怎么设置外键

sql怎么设置外键,第1张

sql server中建立外键约束有3中方式:enterprise manager中,tables,design table,设置table的properties,可以建立constraint, reference keyenterprise manager中,diagrams, new diagrams,建立两个表的关系;直接用transact sql语句。

1、三个方法都需要先建立数据表。

1)创建表author :

create table [dbo].[author] (

[id] [bigint] not null ,

[authorname] [char] (10) null ,

[address] [char] (480)  null ,

[introduction] [ntext]  null

)

2)创建表mybbs:

reate table [dbo].[mybbs] (

[id] [bigint] identity (1, 1) not null ,

[authorid] [bigint] not null ,

[title] [char] (40)  null ,

[date_of_created] [datetime] null ,

[abstract] [char] (480)  null ,

[content] [ntext]  null

)

2、设置表mybbs中的authorid为外键,参照author表的id字段,直接使用transact sql语句,过程如下:

1)增加表mybbs(authorid)的外键约束fk_mybbs_author,表mybbs中的authorid受表author中的主键id约束:

begin transaction

alter table dbo.mybbs add constraint fk_mybbs_author

foreign key (authorid)

references  dbo.author([id]) on update cascade on delete cascade

2)删除外键约束fk_mybbs_author:

--alter table dbo.mybbs drop constraint fk_mybbs_author

--rollback

commit transaction

上面on update cascade,on delete cascade两个选项,指明以后author表的id字段有delete,update *** 作时,mybbs表中的id也会被级联删除或更新。如果没有选中,是不可以对author表中已被mybbs表关联的id进行update或者delete *** 作的。

拓展资料:

SQL的主键和外键的作用:

1、插入非空值时,如果主键表中没有这个值,则不能插入。

2、更新时,不能改为主键表中没有的值。

3、删除主键表记录时,你可以在建外键时选定外键记录一起级联删除还是拒绝删除。

4、更新主键记录时,同样有级联更新和拒绝执行的选择。

简而言之,SQL的主键和外键就是起约束作用。

我们使用sql server创建数据表的时候,经常需要建立表之间的外键约束关系,那么如何添加外键呢?下面我给大家分享一下。

工具/材料

sql server

01

首先我们先来建立两个表,如下图所示,班级表和年级表

02

然后右键单击班级表,在d出的菜单中选择关系选项,如下图所示

03

接下来在d出的表和关系界面中设置外键对应字段,如下图所示

04

最后我们就可以在左侧看见外键约束关系了,如下图所示

建议改成这样

create table 会员证 (

会员编号 varchar(20),

会员姓名 varchar(10),

会员年龄 int,

会员住址 varchar(50),

primary key (会员编号) )

create table 图书 (

书号 int,

书名 varchar(20) not null,

价格 decimal(6,2),

页数 int,

出版社 varchar(50) default '清华大学出版社',

作者 varchar(50),

primary key (书号) )

create table 借阅 (

会员编号 varchar(20) foreign key references 会员证(会员编号),

书号 int foreign key references 图书(书号),

借阅时间 datetime,

归还时间 datetime,

primary key (会员编号,书号,借阅时间) )

一般user表只用一个id或者编号来做主键


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11816791.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存