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
    );
相关推荐
yaoxin521123几秒前
第三章 C 开头的术语
sql·iris
深蓝海拓15 分钟前
Pyside6(PyQT5)中的QTableView与QSqlQueryModel、QSqlTableModel的联合使用
数据库·python·qt·pyqt
C嘎嘎嵌入式开发2 小时前
什么是僵尸进程
服务器·数据库·c++
Yeats_Liao4 小时前
Navicat 导出表结构后运行查询失败ERROR 1064 (42000): You have an error in your SQL syntax;
数据库·sql
明月看潮生5 小时前
青少年编程与数学 02-007 PostgreSQL数据库应用 15课题、备份与还原
数据库·青少年编程·postgresql·编程与数学
明月看潮生5 小时前
青少年编程与数学 02-007 PostgreSQL数据库应用 14课题、触发器的编写
数据库·青少年编程·postgresql·编程与数学
加酶洗衣粉9 小时前
MongoDB部署模式
数据库·mongodb
Suyuoa9 小时前
mongoDB常见指令
数据库·mongodb
添砖,加瓦9 小时前
MongoDB详细讲解
数据库·mongodb
Zda天天爱打卡9 小时前
【趣学SQL】第二章:高级查询技巧 2.2 子查询的高级用法——SQL世界的“俄罗斯套娃“艺术
数据库·sql