MySQL约束(主键,唯一,非空,外键)

MySQL约束(主键,唯一,非空,外键)

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

分类:
1. 主键约束:primary key
2. 非空约束:not null
3. 唯一约束:unique
4. 外键约束:foreign key

目录

  • MySQL约束(主键,唯一,非空,外键)
      • 1. 非空约束
      • 2. 唯一约束
      • 3. 主键约束
      • 4. 外键约束
          • 例子

1. 非空约束

非空约束是为了让数据在存入数据时,保证值不为null。

关键字:not null

1. 创建表时添加约束

CREATE TABLE stu(
			id INT,
			NAME VARCHAR(20) NOT NULL -- name为非空
		);

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

ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;

3. 删除name的非空约束

ALTER TABLE stu MODIFY NAME VARCHAR(20);

2. 唯一约束

唯一约束是为了让数据在存入表时,保证值不唯一。

关键字:unique

1. 创建表时,添加唯一约束

CREATE TABLE stu(
	id INT,
    phone_number VARCHAR(20) UNIQUE --添加了唯一约束
);

注意 MySQL中,唯一约束限定的列的值可以有多个null。

2. 删除唯一约束

ALTER TABLE stu DROP INDIX phone_number;

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

ALTER TABLE stu MADIFY phone_number VARCHAR(20) UNIQUE;

3. 主键约束

主键约束是唯一约束和非空约束的综合体,值既唯一也不能为空。

关键字:primary key

注意:

​ 1.一张表只能有一个字段为主键

​ 2.主键就是表中记录的唯一标识

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

CREATE TABLE stu(
	id INT PRIMARY KEY,  --给id添加主键约束
    name VARCHAR(20)
)

2. 删除主键

ALTER TABLE stu DROP PRIMARY KEY;

3.创建完表后,添加主键

ALTER TABLE stu MODIFY id INT PRIMARY KEY;

4.自动增长

1.概念

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

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

CREATE TABLE stu(
	id INT PRIMARY KEY auto_increment,	--给id添加主键约束
    NAME VARCHAR(20)
);

3.删除自动增长

ALTER TABLE stu MODIFY id INT;

4.添加自动增长

ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;

4. 外键约束

让表于表产生关系,从而保证数据的正确性。

关键字:foreign key

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

语法:

create table 表名(
				....
				外键列
				constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)
			);

2.删除外键

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

3.创建表之后,添加外键

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

4.级联操作

1.添加级联操作

语法:

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE;

2.分类

  1. 级联更新:ON UPDATE CASCADE

    ​ 级联更新,只能是创建表的时候创建级联关系。更新主表中的主键,从表中的外键 列也自动同步更新

  2. 级联删除:ON DELETE CASCADE

    ​ 同步删除

例子

创建一个员工表包含如下列(id, name, age, dep_name, dep_location),

id 主键并自动增长,添加 5 条数据

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 (NAME, age, dep_name, dep_location) VALUES ('张三', 20, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('李四', 21, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('王五', 20, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('老王', 20, '销售部', '深圳');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('大王', 22, '销售部', '深圳');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('小王', 18, '销售部', '深圳');

以上数据表的缺点:

  1. 数据冗余

  2. 后期还会出现增删改的问题

这个时候就要用到我们的外键约束了。

解决方案:

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 -- 外键对应主表的主键
);
-- 添加 2 个部门
insert into department values(null, '研发部','广州'),(null, '销售部', '深圳');
select * from department;
-- 添加员工,dep_id 表示员工所在的部门
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);
select * from employee;

这时候如果把表employee的dep_id列设置外键约束表department的id列,就能够做到让这两个数据之间相关联。

以下是添加外键操作:

ALTER TABLE employee ADD CONSTRAINT ed_fk FOREIGN KEY ( dep_id ) REFERENCES department ( id );

添加外键之后,就不能随意单独修改其中一个的值了。比如想把研发部的id改为5,这时直接修改是改不了的,因为表employee中有三个数据dep_id都是1,如果直接修改表department中的id,那个前面说的三个数据就会找不到对应的键值,所以数据库会在你修改后直接报错来阻止这种事情的发生。要改的话只能先把表employee中dep_id是1的数据设为null,再把department的id列中1改成5,最后还得再把表employee中dep_id的null设为5,才能修改成功。

显然这样是非常麻烦的,这时候我们就需要一种操作叫做级联操作。级联操作是能在修改和删除主表的主键时,同时更新或删除副表的外键值。

因为级联操作是作用在外键上的,所以无法单独添加。因为我们之前已经添加了外键,想要再在外键上添加级联的话要先把外键删除了,然后再在添加外键的语句后面加上ON UPDATE CASCADE \ON DELETE CASCADE即可。

alter table employee drop foreign key ed_fk; --删除外键

ALTER TABLE employee ADD CONSTRAINT ed_fk FOREIGN KEY ( dep_id ) REFERENCES department ( id ) ON UPDATE CASCADE;  --添加外键和级联更新

你可能感兴趣的:(MySQL,mysql,数据库)