数据库外键怎么设置?

数据库外键怎么设置?,第1张

SQL 数据库建表时怎么设置外键,

1>-- 创建测试主表. ID 是主键.

2>CREATE TABLE test_main (

3>id INT,

4>value VARCHAR(10),

5>PRIMARY KEY(id)

6>)

7>go

-- 建表时设置外键

1>CREATE TABLE test_sub (

2>id INT,

3>main_id INT,

4>value VARCHAR(10),

5>PRIMARY KEY(id),

6>FOREIGN KEY (main_id) REFERENCES test_main

7>)

8>go

sql怎么设置外键

可以在创建表的时候创建,也可以在创建表之后创建。

创建表时创建:

create table student

(id int primary key,

name char(4),

dept char(9)

sex char(4))

create table grade

(id int ,

grade int

constraint id_fk foreign key (id) references student (id)

)

或创建了两表之后再建

alter table grade

add constraint id_fk foreign key (id) references student (id)

呵呵,希望能帮助你。

sql server中图形界面如何设置外键

在那个属性上右键 有约束 自己添加就OK了

mysql怎么设置外键?

ALTER TABLE b ADD CONSTRAINT c FOREIGN KEY(c) REFERENCES a(c) ON DELETE CASCADE ON UPDATE CASCADE哎呀。。好像写反了。我写的是把表B的c设置为外键了。。你改一下吧。

如何在数据库的建立表的时候设置表的外键

1>-- 创建测试主表. ID 是主键.

2>CREATE TABLE test_main (

3>id INT,

4>value VARCHAR(10),

5>PRIMARY KEY(id)

6>)

7>go

-- 建表时设置外键

1>CREATE TABLE test_sub (

2>id INT,

3>main_id INT,

4>value VARCHAR(10),

5>PRIMARY KEY(id),

6>FOREIGN KEY (main_id) REFERENCES test_main

7>)

8>go

sql server 2008 怎么设置外键

建外键的前提是此外键必须是另外一个表的主键。建外键的步骤: 第一步打开要建外键表的设计器,右击选择“关系”。然后d出“外键关系”窗体,我们选择“添加”,然后点击“表和列规范”后面的小按钮,就会d出另外一个窗体让我们选择主键表和列,选好之后点击确定。然后我们INSERT和UPDATE规范,在更新规则和删除规则有四个选项,分别是“不执行任何 *** 作”、“级联”、“设置为NULL”、“设置默认值”。默认的不执行任何 *** 作。如果是“不执行任何 *** 作”,当我们删除或更新主键表的数据时,会告诉用户不能执行删除或更新该 *** 作。“级联”的意思是当我们删除或更新主键表的数据时,会删除或更新外键表中所涉及的相关数据的所有行。 “设置Null”的意思是当我们删除或更新主键表的数据时,外键表中的外键列的值会设为Null,但前提是该列允许为空。 “设置默认值”的意思是如果我们将外键列定义了默认值,当我们删除或更新主键表的数据时,外键表中的外键列的值设为定义的默认值。 当然我们可以用代码创建,当我们在创建数据库表T——Card时只要加上一句话就OK啦,“Foreign key (studentNo) references T_Student(studentNo)"。如果我们已经创建了改表,那如何用代码实现了,这也很简单也就一句话“ add constraint CMPKey(外键名) foreign key(studentNo) references T_Student(studentNo)”。

sql中怎样创建外键约束

在创建表之后,添加外键约束:

alter table yuangong add constraint fk foreign key (部门罚) references bumen(部门号)

或者在创建表的时候添加外键

foreign key (部门号) references bumen(部门号)放在最后,用","与列分隔

数据库中,一对多的时候外键设置在多的那张表吗?如果一对一的时候,外键应该设置在哪里?多对多的时候,

首先,外键引用的那个列在主表中必须是主键列或者唯一列。

所以1:n的肯定把外键建立在n的那张表上。

1:1,一般要看谁是主表,谁是附属表,外键当然建立在附属表中。

n:m的情况,需要建立一个关系表,两个原表和其关系分别是1:n,1

:m

数据库语句怎么加外键

1,创建表的时候添加:foreign key (你的外键) references (表名)(字段名)

2,创建好之后修改:

alter table dbo.mh_User

add constraint FK_mh_User_..._id foreign key (你的外键) references (表名)(字段名)

Sql server怎样创建主外键关系

在要设置关系的外键表中,右击关系→添加→在表和列规范中选择关联的主表再选择外键表与其关联的字段

CASCADE:父表delete、update的时候,子表会delete、update掉关联记录;

SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为not null;

RESTRICT:如果想要删除父表的记录时,而在子表中有关联该父表的记录,则不允许删除父表中的记录;

NO ACTION:同 RESTRICT,也是首先先检查外键

对表中的数据进行限定,保证数据的正确性、有效性和完整性。

分类:

①、主键约束:primary key

②、非空约束:not null

③、唯一约束:unique

④、外键约束:foreign key

一、非空约束:not null,某一列的值不能为null

创建表时添加约束

CREATE TABLE stu(

id INT,

NAME VARCHAR(20) NOT NULL -- name为非空

)

1

2

3

4

1

2

3

4

创建表完后,添加非空约束

CREATE TABLE stu(

id INT,

NAME VARCHAR(20)

)

ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL

1

2

3

4

5

6

1

2

3

4

5

6

在这里插入图片描述

删除name的非空约束

ALTER TABLE stu MODIFY NAME VARCHAR(20)

1

1

在这里插入图片描述

二、唯一约束:unique,某一列的值不能重复

注意:唯一约束可以有NULL值,但是只能有一条记录为null

在创建表时,添加唯一约束

CREATE TABLE stu(

id INT,

phone_number VARCHAR(20) UNIQUE -- 手机号

)

1

2

3

4

1

2

3

4

在这里插入图片描述

删除唯一约束

ALTER TABLE stu DROP INDEX phone_number

1

1

在这里插入图片描述

在表创建完后,添加唯一约束

ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE

1

1

三、主键约束:primary key。

注意:

①、含义:非空且唯一

②、一张表只能有一个字段为主键

③、主键就是表中记录的唯一标识

在创建表时,添加主键约束

create table stu(

id int primary key,-- 给id添加主键约束

name varchar(20)

)

1

2

3

4

1

2

3

4

在这里插入图片描述

删除主键

-- 错误 alter table stu modify id int

ALTER TABLE stu DROP PRIMARY KEY

1

2

1

2

在这里插入图片描述

创建完表后,添加主键

create table stu(

id int,

name varchar(20)

)

ALTER TABLE stu MODIFY id INT PRIMARY KEY

1

2

3

4

5

6

1

2

3

4

5

6

自动增长:

①、概念:如果某一列是数值类型的,使用 auto_increment 可以来完成值得自动增长

②、在创建表时,添加主键约束,并且完成主键自增长

create table stu(

id int primary key auto_increment,-- 给id添加主键约束

name varchar(20)

)

1

2

3

4

1

2

3

4

在这里插入图片描述

③、 删除自动增长

ALTER TABLE stu MODIFY id INT

1

1

在这里插入图片描述

④、添加自动增长

ALTER TABLE stu MODIFY id INT AUTO_INCREMENT

1

1

四、外键约束:foreign key,让表于表产生关系,从而保证数据的正确性。

CREATE TABLE emp(

id INT PRIMARY KEY AUTO_INCREMENT,

NAME VARCHAR(30),

age INT,

dep_name VARCHAR(30),

dep_location VARCHAR(30)

)

INSERT INTO emp VALUES (1, '张三', 20, '研发部', '广州')

INSERT INTO emp VALUES (2, '李四', 21, '研发部', '广州')

INSERT INTO emp VALUES (3, '王五', 20, '研发部', '广州')

INSERT INTO emp VALUES (4, '老王', 20, '销售部', '深圳')

INSERT INTO emp VALUES (5, '大王', 22, '销售部', '深圳')

INSERT INTO emp VALUES (6, '小王', 18, '销售部', '深圳')

1

2

3

4

5

6

7

8

9

10

11

12

13

14

1

2

3

4

5

6

7

8

9

10

11

12

13

14

在这里插入图片描述

通过上面的表格,我们可以知道,表中的信息是员工在不同的部门里面,于是我们可以将上面的一张表分开,分成两张表格。一张部门的表,一张员工的表。

-- 创建部门表(id,dep_name,dep_location)

CREATE TABLE department(

id INT PRIMARY KEY AUTO_INCREMENT,

dep_name VARCHAR(20),

dep_location VARCHAR(20)

)

-- 创建员工表(id,name,age,dep_id)

CREATE TABLE employee(

id INT PRIMARY KEY AUTO_INCREMENT,

NAME VARCHAR(20),

age INT,

dep_id INT -- 外键对应主表的主键

)

-- 添加两个部门

INSERT INTO department VALUES(NULL, '研发部','广州'),(NULL ,'销售部', '深圳')

-- 添加员工信息

INSERT INTO employee (NAME,age,dep_id) VALUES('张三',20,1)

INSERT INTO employee (NAME,age,dep_id) VALUES('李四',21,1)

INSERT INTO employee (NAME,age,dep_id) VALUES('王五',20,1)

INSERT INTO employee (NAME,age,dep_id) VALUES('老王',20,2)

INSERT INTO employee (NAME,age,dep_id) VALUES('大王',22,2)

INSERT INTO employee (NAME,age,dep_id) VALUES('小王',18,2)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

在这里插入图片描述

倘若现在我们把删除department表里面的数据,是可以删除的;但是这不符合实际情况。因为我们此时虽然删除掉了deparment表里的数据,但是employee表里面还是存在部门的信息。只有当部门里面的员工全部开除后,我们才可以删除部门表。

1.添加外键

在创建表时,可以添加外键:

create table 表名(

....

外键列

constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)

)

1

2

3

4

5

1

2

3

4

5

-- 创建员工表(id,name,age,dep_id)

CREATE TABLE employee(

id INT PRIMARY KEY AUTO_INCREMENT,

NAME VARCHAR(20),

age INT,

dep_id INT, -- 外键对应主表的主键

CONSTRAINT emp_dept_fk FOREIGN KEY (dep_id) REFERENCES department(id)

)

1

2

3

4

5

6

7

8

1

2

3

4

5

6

7

8

删除外键

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称

1

1

创建表之后,添加外键

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称)

1

1

2. 级联 *** 作

我们如果要是直接在deparment表中直接将id=1修改为id=5的话,是不可以的。因为department的id被关联到employee表中了,所以修改会产生错误。;但是我们可以通过级联 *** 作进行修改。

添加级联 *** 作

语法:

ALTER TABLE 表名 ADD CONSTRAINT 外键名称

FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称)

ON UPDATE CASCADE ON DELETE CASCADE

1

2

3

1

2

3

分类:

①、级联更新:ON UPDATE CASCADE

②、级联删除:ON DELETE CASCADE

示例演示:

①、删除外键employee表中的外键(因为此时表中已经添加外键,需要先删除)

-- 删除外键

ALTER TABLE employee DROP FOREIGN KEY emp_dept_fk

1

2

1

2

②、添加外键的同时,还要添加级联 *** 作

ALTER TABLE employee ADD CONSTRAINT emp_dept_fk FOREIGN KEY ( dep_id ) REFERENCES department ( id ) ON UPDATE CASCADE ON DELETE CASCADE

1

1

③、倘若我们现在要是删除employee表中id=1的数据,那么department表中的数据也会跟着一起更新数据。

delete from department where id=1

1

1

-- 查询department表数据

select * from department

1

2

1

2

在这里插入图片描述

-- 查询employee表数据

select * from employee

1

2

1

2

在这里插入图片描述


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

原文地址:https://54852.com/sjk/9905267.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存