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
    );
相关推荐
月光水岸New1 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6751 小时前
数据库基础1
数据库
我爱松子鱼1 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo1 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser2 小时前
【SQL】多表查询案例
数据库·sql
Galeoto2 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)3 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231113 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql
喝醉酒的小白3 小时前
PostgreSQL:更新字段慢
数据库·postgresql
敲敲敲-敲代码3 小时前
【SQL实验】触发器
数据库·笔记·sql