数据库外键设置
① 数据库语句怎么加外键
1、以具有 DBA 权限的用户身份连接到数据库,执行 ALTER TABLE 语句,将表定义更新为包括外键定义。创建一个名为 Skills 的表,其中包含潜在技能列表,然后创建一个与 Skills 表具有外键关系、名为 EmployeeSkills 的表。
② sql用命令创建主键与外键。
1、为了方便大家理解,使用一个例子来帮助大家理解。意思闷敏洞大概就是通过蚂枯引用表二中的字段完成对表一字段的约束。方法:
③ 数据库之主键外键
1,主键约束 (table的唯一标识)
能够作为主键列的特点:该列不能为空,不能有重复值出现
创建表时指定主键的两种方式:
CREATE TABLE stu(
sid CHAR(6) PRIMATY KEY,
sname VARCHAR(20),
age INT,
gender VARCHER(10)
);
指定sid列为主键列
CREATE TABLE stu(
sid CHAR(6),
sname VARCHAR(20),
age INT,
gender VARCHER(10),
PRIMARY KEY(sid)
);
指定sid列为主键列
修改表时指定主键:ALTER TABLE stu ADD PRIMATY KEY(sid);
删除主键:ALTER TABLE stu DROP PRIMARY KEY;
2,主键自增长
因为主键列的特性是:必须唯一,不能为空,所以我们通常会指定主键为整形,然后设置其自动增长
创建表时指定主键自增长:
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20),
age INT,
gender VARCHAR(10)
);
修改表时设置主键自增长:ALTER TABLE stu
3,非空约束
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20) NOT NULL,
age INT,
gender VARCHAR(10)
);
对sname列设置了非空约束
4,唯一约束
某些列不能设置重复的值,所以可以对列添加唯一约束
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20) NOT NULL UNIQUE,
age INT,
gender VARCHAR(10)
);
6,外键约束
外键特点:外键必须是另一个表的主键的值(外键要引用主键!),外键可以重复,外键可以为空,一张表可以有多个外键!
CREATE TABLE dept( //部门表
deptno INT PRIMARY KEY AUTO_INCREMENT,
deptname CHAR(20)
);
INSERT INTO dept VALUES(10,‘研发部’);
INSERT INTO dept VALUES(20,‘人力部’);
INSERT INTO dept VALUES(30,‘财务部’);
CREATE TABLE emp( //员工表
empno INT PRIMARY KEY AUTO_INCREMENT,
ename VARCHAR(50),
dno INT, //员工所属部门(外键),
CONSTRAINT fk_emp_dept FOREIGN KEY(dno) REFERENCES dept(deptno)
);
INSERT INTO emp(empno,ename) VALUES(NULL,‘张三’),//外键可以不传入值
INSERT INTO emp(empno,ename) VALUES(NULL,‘李四’,10),//外键可以重复
INSERT INTO emp(empno,ename) VALUES(NULL,‘王五’,10),
INSERT INTO emp(empno,ename) VALUES(NULL,‘赵六’,80),//dept表没有主键值为80的记录,sql客户端编译报错
7,一对一关系模型
创建老公表
CREATE TABLE hashand(
hid INT PRIMARY KEY AUTO_INCREMENT,
hname VARCHAR(50),
);
INSERT INTO hashand VALUES(NULL,‘刘备’);
INSERT INTO hashand VALUES(NULL,‘关羽’);
INSERT INTO hashand VALUES(NULL,‘张飞’);
SELECT * FROM hashand
//创建老婆表
CREATE TABLE wife(
wid INT PRIMARY KEY AUTO_INCREMENT,
wname VARCHAR(50),
CONSTRAINT fk_wife_hashand FOREIGN KEY(wid) REFERENCES hashand(hid)
)
/**
wid:
1,非空
2,唯一
3,引用hid
*/
INSERT INTO wife VALUES(1,‘杨贵妃’);
INSERT INTO wife VALUES(2,‘妲己’);
INSERT INTO wife VALUES(3,‘褒姒’);
SELECT * FROM wife;
对于一对一关系模型从表的主键即是外键,例如老公和老婆的关系模型,一个老公只能有一个老婆,一个老婆只能有一个老公
对于一对多关系模型主表的主键即是从表的外键,例如订单和用户的关系模型,一个用户可以下单多次,对应多个订单,而一个订单只能属于一个用户
对于多对多关系模型没有主表和从表之分,需要建立第三张表来记录这两张表的外键,建立两个外键,分别引用这两张表的主键
8,多对多关系模型
在表中简历多对多关系需要使用中间表,即需要三张表,在中间表中使用两个外键,分别引用其他两个表的主键,例如学生和老师的关系模型,一个老师可以有多个学生,一个学生可以有多个老师
CREATE TABLE student(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname CHAR(40)
);
CREATE TABLE teacher(
tid INT PRIMARY KEY AUTO_INCREMENT,
tname CHAR(40)
);
CREATE TABLE stu_tea(
sid INT,
tid INT,
ADD CONSTRAINT fk_stu_tea_sid FOREIGN KEY(sid) REFERENCES student(sid),
ADD CONSTRAINT fk_stu_tea_tid FOREIGN KEY(tid) REFERENCES teacher(tid)
);
INSERT INTO student VALUES(NULL,‘刘德华’);
INSERT INTO student VALUES(NULL,‘梁朝伟’);
INSERT INTO student VALUES(NULL,‘黄日华’);
INSERT INTO student VALUES(NULL,‘苗侨伟’);
INSERT INTO student VALUES(NULL,‘汤镇业’);
INSERT INTO teacher VALUES(NULL,‘崔老师’);
INSERT INTO teacher VALUES(NULL,‘刘老师’);
INSERT INTO teacher VALUES(NULL,‘石老师’);
SELECT * FROM student;
SELECT * FROM teacher;
INSERT INTO stu_tea VALUES(1,1); //刘德华是崔老师的学生
INSERT INTO stu_tea VALUES(2,1); //梁朝伟是崔老师的学生
INSERT INTO stu_tea VALUES(3,1);//黄日华是崔老师的学生
INSERT INTO stu_tea VALUES(4,1);//苗侨伟是崔老师的学生
INSERT INTO stu_tea VALUES(5,1);//汤镇业是崔老师的学生
INSERT INTO stu_tea VALUES(2,2);//梁朝伟是刘老师的学生
INSERT INTO stu_tea VALUES(3,2);//黄日华是刘老师的学生
INSERT INTO stu_tea VALUES(4,2);//苗侨伟是刘老师的学生
INSERT INTO stu_tea VALUES(3,3);//黄日华是石老师的学生
INSERT INTO stu_tea VALUES(5,3);//汤镇业是刘老师的学生
SELECT * FROM stu_tea;
这时在stu_tea这个中间表中的每条记录都是来说明student表和teacher表的关系的
例如在stu_tea表中的记录:sid为1001,tid为2001,这说明编号为1001的学生有一个编号为2001的老师
sid tid
1001 2001 //编号为1001的学生有一个编号为2001的老师
1001 2002 //编号为1001的学生有一个编号为2002的老师
1001 2003 //编号为1001的学生有一个编号为2003的老师
1002 2001 //编号为2001的老师有一个编号为1002的学生
1002 2004 //编号为2004的老师有一个编号为1002的学生
9,合并结果集
要求要合并的结果集中,列的类型和列数相同
UNION,去除重复行,UNION ALL,不去除重复行