SQL中的约束

约束(CONSTRAINT)

对表中字段的限制

  1. 非空约束NOT NULL

    只能声明在每个字段的后面

    sql 复制代码
    CREATE TABLE test(
    id INT NOT NULL,
    last_name VARCHAR(15),
    phone VARCHAR(20) NOT NULL
    );
  2. 唯一性约束UNIQUE

    说明:

    ① 可以声明在字段的后面,也可以声明在表的后面

    ② 如果不指定约束名字,默认和字段名相同

    ③ 设置UNIQUE的字段,可以有多条记录是NULL

    ④ 表级约束,可以将多个字段组合成唯一性约束

    在创建表时,设置唯一性约束

    sql 复制代码
    CREATE TABLE test(
    id INT UNIQUE, # 列级的唯一性约束
    last_name VARCHAR(15),
    email VARCHAR(25),
    salary DECIMAL(10,2),
    CONSTRAINT uk_test_email UNIQUE(email) # 表级的唯一性约束,指明约束名称
    # UNIQUE(email) #表级的唯一性约束,不指定约束名,简写形式
    # CONSTRAINT uk_test_id_email UNIQUE(id, email) # 表级唯一性约束
    );

    修改唯一性约束

    sql 复制代码
    # 方式一
    ALTER TABLE test
    ADD CONSTRAINT uk_test_salary UNIQUE(salary);
    # ADD UNIQUE(salary) #不指定约束名,简写形式
    
    #方式二
    ALTER TABLE test
    MODIFY salary DECIMAL(10,2) UNIQUE;

    删除唯一性约束

    说明

    ① 添加唯一性约束的列上,也会自动创建唯一索引

    ② 删除唯一性约束只能通过删除唯一索引的方式

    ③ 删除时需要指定唯一索引名(与唯一性约束名相同)

    ④ 如果创建唯一约束时未指定约束名,如果是单列,默认和字段名一致,如果是多列,默认是()中第一个字段名相同

    sql 复制代码
    ALTER TABLE test
    DROP INDEX 唯一索引名;

    查看表中的唯一索引

    sql 复制代码
    SHOW INDEX FROM 表名;
  3. 主键约束PRIMARY KEY

    说明:

    ① 一个表中只能有一个主键约束,要么单列,要么复合列

    ② 主键约束的列不能为NULL,且不能重复

    ③ 主键名为PRIMARY,不可修改

    ④ 用于唯一标识表中的一条记录

    sql 复制代码
    CREATE TABLE test(
    id INT PRIMARY KEY, # 列级约束
    last_name VARCHAR(15),
    salary DECIMAL(10,2)
    # CONSTRAINT PRIMARY KEY(id) #表级约束
    # PRIMARY KEY(id, last_name) #复合主键约束
    );
    
    # 删除主键约束
    ALTER TABLE test
    DROP PRIMARY KEY;
  4. 自增列AUTO_INCREMENT

    说明

    ① 某个字段值的自增

    ② 一个表中最多有一个自增长列

    ③ 自增长列必须是键列(PRIMARY KEYUNIQUE

    ④ 自增列必须是整数类型

    ⑤ 当向自增列添加0或NULL时,实际上会设置成自增值

    sql 复制代码
    CREATE TABLE test(
    id INT PRIMARY KEY AUTO_INCREMENT,
    last_name VARCHAR(15),
    salary DECIMAL(10,2)
    );
    
    # 删除自增列
    ALTER TABLE test
    MODIFY id INT;
  5. 外键约束FOREIGN KEY

    说明

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

    ② 从表的外键列,必须是主表的主键或唯一约束

    ③ 在创建外键约束时,如果不手动命名,则会自动产生一个外键名

    sql 复制代码
    # 创建主表
    CREATE TABLE departments(
    id INT PRIMARY KEY AUTO_INCREMENT,
    `name` VARCHAR(15)
    );
    # 创建从表
    CREATE TABLE employees(
    id INT PRIMARY KEY AUTO_INCREMENT,
    last_name VARCHAR(15),
    department_id INT,
    CONSTRAINT fk_emp_dept_id FOREIGN KEY (department_id) REFERENCES departments(id)
    );

    约束等级

    CASCADE:在父表上update/delete记录时,同步update/delete子表上匹配的记录

    SET NULL:在父表上update/delete记录时,将子表上匹配的记录设置为NULL(子表外键不能为NOT NULL)

    NO ACTION:如果子表中引用了父表中的内容,则不允许删除父表中被引用的记录

    RESTRICT:同NO ACTION

    SET DEFAULT:父表有变更时,子表对应字段会设置成默认值

    sql 复制代码
    # 当主表修改主键时,从表所有引用的部分也会响应修改
    # 当主表删除某条数据时,从表所有引用的部分会设置成NULL
    CREATE TABLE employees(
    id INT PRIMARY KEY AUTO_INCREMENT,
    last_name VARCHAR(15),
    department_id INT,
    FOREIGN KEY (department_id) REFERENCES departments(id) ON UPDATE CASCADE ON DELETE SET NULL
    );
    
    # 删除外键约束
    ALTER TABLE employees
    DROP FOREIGN KEY 外键约束名;
  6. 检查约束CHECK

    说明

    ① 检查某个字段的值是否符合某些要求,一般指值的范围

    sql 复制代码
    CREATE TABLE employees(
    id INT PRIMARY KEY AUTO_INCREMENT,
    last_name VARCHAR(15),
    salary DECIMAL(10,2) CHECK(salary > 3000)
    );
  7. 默认值约束DEFAULT

    sql 复制代码
    CREATE TABLE test(
    id INT PRIMARY KEY AUTO_INCREMENT,
    last_name VARCHAR(15),
    salary DECIMAL(10,2) DEFAULT 2000
    );
相关推荐
GOTXX20 分钟前
BoostSiteSeeker项目实战
前端·c++·后端·mysql·搜索引擎·项目实战·boost
cwtlw22 分钟前
JavaRedis和数据库相关面试题
java·数据库·笔记·面试
Wo3Shi4七1 小时前
MySQL底层原理(第一期)
数据库·后端·mysql
镜舟科技1 小时前
迈向云原生:理想汽车 OLAP 引擎变革之路
大数据·数据库·云原生
山山而川粤1 小时前
SSM考研信息查询系统
java·大数据·运维·服务器·开发语言·数据库·考研
林十一npc1 小时前
MySQL索引与视图综合应用示例解析
android·前端·mysql
Breeze1 小时前
MySQL架构原理深度剖析
mysql
Arbori_262151 小时前
oracle常用sql
数据库·sql·oracle
SuperherRo1 小时前
Web开发-JavaEE应用&ORM框架&SQL预编译&JDBC&MyBatis&Hibernate&Maven
前端·sql·java-ee·maven·mybatis·jdbc·hibernate
萱萱1995041 小时前
Spring Boot实战:MySQL与Redis数据一致性深度解析与代码实战
spring boot·redis·mysql