MySQL7种约束还不懂? 万字整理MySQL约束,哪里不会点哪里,还不赶紧上车?(二)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL7种约束还不懂? 万字整理MySQL约束,哪里不会点哪里,还不赶紧上车?(二)

❤三、PRIMARY KEY 约束

1、作用

用来唯一标识表中的一行记录。


2、特点

主键约束相当于唯一约束+非空约束的组合,主键约束列不允许重复,也不允许出现空值`


一个表最多只能有一个主键约束,建立主键约束可以在列级别创建,也可以在表级别上创建


主键约束对应着表中的一列或者多列(复合主键)


如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值不允许重复


MySQL的主键名总是PRIMARY,就算自己命名了主键约束名也没用


当创建主键约束时,系统默认会在所在的列或列组合上建立对应的主键索引(能够根据主键查询的,就根据主键查询,效率更高)。如果删除主键约束了,主键约束对应的索引就自动删除了


不要修改主键字段的值,因为主键是数据记录的唯一标识,如果修改了主键的值,就有可能会破坏数据的完整性。


3、添加主键约束

(1)建表时指定主键约束


语法结构:


create table 表名称(
  字段名  数据类型  primary key, #列级模式
    字段名  数据类型  
);
create table 表名称(
  字段名  数据类型,
    字段名  数据类型,
    [constraint 约束名] primary key(字段名) #表级模式,[]内设置约束名
);


举例:


#列级约束
create table temp(
  id int primary key,
    name varchar(20)
);
insert into temp values(1,'张三');#成功
insert into temp values(1,'张三');#失败
ERROR 1062 (23000): Duplicate(重复) entry(键入,输入) '1' for key 'PRIMARY'
insert into temp values(1,'王五');#失败
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
insert into temp values(4,null);#成功
insert into temp values(null,'李琦');#失败
ERROR 1048 (23000): Column 'id' cannot be null



#表级约束
CREATE TABLE emp5(
id INT NOT NULL AUTO_INCREMENT,
NAME VARCHAR(20),
pwd VARCHAR(15),
CONSTRAINT emp5_id_pk PRIMARY KEY(id)
);


(2)建表后增加主键约束


ALTER TABLE 表名 ADD PRIMARY KEY(字段列表); #字段列表可以是一个字段,也可以是多个字段,如果是多个字段的话,是复合主键(表级约束)


ALTER TABLE student ADD PRIMARY KEY (sid);


ALTER TABLE emp5 ADD PRIMARY KEY(NAME,pwd);


4、关于复合主键

语法结构:


create table 表名称(

字段名  数据类型,
    字段名  数据类型,  
    字段名  数据类型,
    primary key(字段名1,字段名2)  #表示字段1和字段2的组合是唯一的,也可以有更多个字段
);


#学生表
create table student(
  sid int primary key,  #学号
    sname varchar(20)     #学生姓名
);
#课程表
create table course(
  cid int primary key,  #课程编号
    cname varchar(20)     #课程名称
);
#选课表
create table student_course(
  sid int,
    cid int,
    score int,
    primary key(sid,cid)  #复合主键
);
insert into student values(1,'张三'),(2,'李四');
insert into course values(1001,'Java'),(1002,'MySQL');
insert into student_course values(1, 1001, 89),(1,1002,90),(2,1001,88),(2,1002,56);



上述插入语句都成功,说明其复合主键约束跟复合唯一性约束在功能上差不多。即两个主键约束满足一个就可以


CREATE TABLE emp(
age INT ,
`name` VARCHAR(25),
id INT UNIQUE ,
#取别名,但是没有用
CONSTRAINT emp_py PRIMARY KEY(age,`name`)
);


查看结果:

image.png


5、删除主键约束

alter table 表名 drop primary key;


举例:


ALTER TABLE emp DROP PRIMARY KEY;


说明:删除主键约束,不需要指定主键名,因为一个表只有一个主键,删除主键约束后,非空还存在。


如下图: 非空依然存在



❤四、FOREIGN KEY 约束

1、作用

限定某个表的某个字段的引用完整性。


比如:员工表的员工所在部门的选择,必须在部门表能找到对应的部分。


2、主表和从表

主表:被引用的表,被参考的表


从表:引用别人的表,参考别人的表


例如:员工表的员工所在部门这个字段的值要参考部门表:部门表是主表,员工表是从表。


例如:学生表、课程表、选课表:选课表的学生和课程要分别参考学生表和课程表,学生表和课程表是主表,选课表是从表。


3、特点(没事看看)

从表的外键列,必须引用/参考主表的主键或唯一约束的列

在创建外键约束时,如果不给外键约束命名,默认名不是列名,而是自动产生一个外键名

创建(CREATE)表时就指定外键约束的话,先创建主表,再创建从表

删表时,先删从表(或先删除外键约束),再删除主表

当主表的记录被从表参照时,主表的记录将不允许删除,如果要删除数据,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据

在从表中指定外键约束,并且一个表可以建立多个外键约束

从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致

当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是外键的约束名。(根据外键查询效率很高)

删除外键约束后,必须手动删除对应的索引

4、添加外键约束

(1)建表时


create table 主表名称(
  字段1  数据类型  primary key,
    字段2  数据类型
);
create table 从表名称(
  字段1  数据类型  primary key,
    字段2  数据类型,
    [CONSTRAINT <外键约束名称>] FOREIGN KEY(从表的某个字段) references 主表名(被参考字段)
);
#(从表的某个字段)的数据类型必须与主表名(被参考字段)的数据类型一致,逻辑意义也一样
#(从表的某个字段)的字段名可以与主表名(被参考字段)的字段名一样,也可以不一样
-- FOREIGN KEY: 在表级指定子表中的列
-- REFERENCES: 标示在父表中的列


create table dept( #主表
  did int primary key,  #部门编号
    dname varchar(50)   #部门名称
);
create table emp(#从表
  eid int primary key,  #员工编号
    ename varchar(5),     #员工姓名
    deptid int,    #员工所在的部门
    foreign key (deptid) references dept(did)   #在从表中指定外键约束
    #emp表的deptid和和dept表的did的数据类型一致,意义都是表示部门的编号
);


说明: 主表dept必须先创建成功,然后才能创建emp表,指定外键成功。 删除表时,先删除从表emp,再删除主表dept


(2)建表后


语法格式:


ALTER TABLE 从表名 ADD [CONSTRAINT 约束名] FOREIGN KEY (从表的字段) REFERENCES 主表名(被引用字段) [on update xx][on delete xx];


举例:


ALTER TABLE emp1
ADD [CONSTRAINT emp_dept_id_fk] FOREIGN KEY(dept_id) REFERENCES dept(dept_id);


create table dept(
  did int primary key,  #部门编号
    dname varchar(50)   #部门名称
);
create table emp(
  eid int primary key,  #员工编号
    ename varchar(5),     #员工姓名
    deptid int    #员工所在的部门
);
#这两个表创建时,没有指定外键的话,那么创建顺序是随意


alter table emp add foreign key (deptid) references dept(did);


5、 约束等级(了解)

Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录


Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null


No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作


Restrict方式:同no action, 都是立即检查外键约束


Set default方式(在可视化工具SQLyog中可能显示空白):父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别


如果没有指定等级,就相当于Restrict方式。


对于外键约束,最好是采用: ON UPDATE CASCADE ON DELETE RESTRICT 的方式。


举例: on update cascade on delete cascade


create table dept(
  did int primary key,  
    dname varchar(50)   
);
create table emp(
  eid int primary key,  
    ename varchar(5),     
    deptid int,    
    foreign key (deptid) references dept(did)  on update cascade on delete cascade
    #即当删除或修改主表的primary key 对应列的值时,从表中的列数据也会对应删除
);


insert into dept values(1001,'教学部');
insert into dept values(1002, '财务部');
insert into dept values(1003, '咨询部');
insert into emp values(1,'张三',1001); #在添加这条记录时,要求部门表有1001部门
insert into emp values(2,'李四',1001);
insert into emp values(3,'王五',1002);
#删除主表的记录成功,主表的1001行被删除了,从表相应的记录也被删除了
delete from dept where did=1001;


如图所示:


image.png

6、删除外键约束

流程如下:

(1)第一步先查看约束名和删除外键约束
SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称';#查看某个表的约束名
ALTER TABLE 从表名 DROP FOREIGN KEY 外键约束名;
(2)第二步查看索引名和删除索引。(注意,只能手动删除)
SHOW INDEX FROM 表名称; #查看某个表的索引名
ALTER TABLE 从表名 DROP INDEX 索引名;


举例:


SELECT * FROM information_schema.table_constraints WHERE table_name = 'emp';
ALTER TABLE emp DROP FOREIGN KEY emp_ibfk_1;
SHOW INDEX FROM emp;
ALTER TABLE emp DROP INDEX deptid;
SHOW INDEX FROM emp;


如图所示:

image.png


7、阿里开发规范

【强制】不得使用外键与级联,一切外键概念必须在应用层解决。


说明: 学生表中的 student_id 是主键,那么成绩表中的 student_id 则为外键。如果更新学生表中的 student_id,同时触发成绩表中的 student_id 更新,即为级联更新。外键与级联更新适用于单机低并发,不适合分布式、高并发集群;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的插入速度。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
8天前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
7天前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
2月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
34 1
|
3月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
90 4
|
4月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
4月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
70 1
|
9天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
34 3
|
9天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
34 3
|
9天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
49 2