相关推荐recommended
SQL语句 -非空约束 - 唯一约束 - 主键约束 - 默认约束 -外键约束
作者:mmseoamin日期:2023-12-13

文章目录

  • 约束
    • 约束介绍和分类
    • 非空约束
    • 唯一约束
    • 主键约束
    • 默认约束
    • 案例练习
    • 外键约束

      约束

      约束介绍和分类

      约束的概念:

      约束是作用于表中列上的规则,用于限制加入表的数据

      约束的存在保证了数据库中数据的正确性、有效性和完整性

      约束的分类如下:

      约束名称描述关键字
      非空约束保证列中所有数据不能有null值NOT NULL
      唯一约束保证列中所有数据各不相同UNIQUE
      主键约束主键是一行数据的唯一标识, 要求非空且唯一PRIMARY KEY
      检查约束保证列中的值满足某一条件CHECK
      默认约束保存数据时, 未指定值则采用默认值DEFAULT
      外检约束外键用来让两个表的数据之间建立连接, 保证数据的一致性和完整性FOREING KEY

      注意: MySQL不支持检查约束

      非空约束

      概念: 非空约束用于保证列中所有数据不能有NULL值

      语法:

      添加约束:

      -- 创建表时添加非空约束
      CREATE TABLE 表名(
         列名 数据类型 NOT NULL,
         …
      ); 
      -- 建完表后添加非空约束
      ALTER TABLE 表名 MODIFY 字段名 数据类型 NOT NULL;
      

      删除约束:

      ALTER TABLE 表名 MODIFY 字段名 数据类型;
      

      唯一约束

      概念: 唯一约束用于保证列中所有数据各不相同

      语法:

      添加约束:

      -- 创建表时添加唯一约束
      CREATE TABLE 表名(
         列名 数据类型 UNIQUE [AUTO_INCREMENT],
         -- AUTO_INCREMENT: 当不指定值时自动增长
         …
      ); 
      CREATE TABLE 表名(
         列名 数据类型,
         …
         [CONSTRAINT] [约束名称] UNIQUE(列名)
      ); 
      -- 建完表后添加唯一约束
      ALTER TABLE 表名 MODIFY 字段名 数据类型 UNIQUE;
      

      删除约束

      ALTER TABLE 表名 DROP INDEX 字段名;
      

      主键约束

      概念:

      主键是一行数据的唯一标识,要求非空且唯一

      一张表只能有一个主键

      语法:

      添加约束: AUTO_INCREMENT表示主键自增

      -- 创建表时添加主键约束
      CREATE TABLE 表名(
         列名 数据类型 PRIMARY KEY [AUTO_INCREMENT],
         …
      ); 
      CREATE TABLE 表名(
         列名 数据类型,
         [CONSTRAINT] [约束名称] PRIMARY KEY(列名)
      );
      -- 建完表后添加主键约束
      ALTER TABLE 表名 ADD PRIMARY KEY(字段名);
      

      删除约束:

      ALTER TABLE 表名 DROP PRIMARY KEY;
      

      默认约束

      概念: 保存数据时,未指定值则采用默认值

      语法:

      添加约束:

      -- 创建表时添加默认约束
      CREATE TABLE 表名(
         列名 数据类型 DEFAULT 默认值,
         …
      ); 
      -- 建完表后添加默认约束
      ALTER TABLE 表名 ALTER 列名 SET DEFAULT 默认值;
      

      删除约束:

      ALTER TABLE 表名 ALTER 列名 DROP DEFAULT;
      

      案例练习

      按照下面图片中的要求, 为表添加合适的约束:

      SQL语句 -非空约束 - 唯一约束 - 主键约束 - 默认约束 -外键约束,在这里插入图片描述,第1张

      语句演示:

      CREATE TABLE emp (
      	id INT PRIMARY KEY AUTO_INCREMENT,
      	ename VARCHAR(50) NOT NULL UNIQUE,
      	joindate DATE NOT NULL,
      	salary DOUBLE(7,2) NOT NULL,
      	bonus DOUBLE(7,2) DEFAULT 0
      );
      

      外键约束

      概念: 外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性

      语法:

      添加约束:

      -- 创建表时添加外键约束
      CREATE TABLE 表名(
         列名 数据类型,
         …
         [CONSTRAINT] [外键名称] FOREIGN KEY(外键列名) REFERENCES 主表(主表列名) 
      ); 
      -- 建完表后添加外键约束
      ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
      

      删除约束:

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

      案例练习

      例如我们有如下两张表, 员工表和部门表, 在没有添加外键约束的时候, 是可以直接删除部门表的研发部的;但是我们知道这是不合理的, 因为员工表中, 前三个员工是属于研发部的, 在有员工属于研发部的情况下应该不能删除才合理;

      我们可以通过外键约束解决这个问题, 将两张表建立连接: 添加外键, emp表的dep_id关联dept表的id主键;

      SQL语句 -非空约束 - 唯一约束 - 主键约束 - 默认约束 -外键约束,在这里插入图片描述,第2张

      创建部门表(注意要先创建部门表), 将id设置为主键, 并添加两个部门

      -- 部门表
      CREATE TABLE dept(
      	id INT PRIMARY KEY AUTO_INCREMENT,
      	dep_name varchar(20),
      	addr varchar(20)
      );
      -- 添加两个部门
      INSERT INTO dept(dep_name, addr) VALUES('研发部','广州'),('销售部', '深圳');
      

      创建员工表添加员工, 并为员工表emp添加外键约束

      -- 员工表 
      CREATE TABLE emp(
      	id INT PRIMARY KEY AUTO_INCREMENT,
      	name VARCHAR(20),
      	age INT,
      	dep_id INT,
      	-- 添加外键 dep_id,关联 dept 表的id主键
      	CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES dept(id)
      );
      -- 添加员工,dep_id 表示员工所在的部门
      INSERT INTO emp (NAME, age, dep_id) VALUES 
      ('张三', 20, 1),
      ('李四', 20, 1),
      ('王五', 20, 1),
      ('赵六', 20, 2),
      ('孙七', 22, 2),
      ('周八', 18, 2);
      

      不需要可以删除外键

      -- 删除外键
      ALTER TABLE emp DROP FOREIGN KEY fk_emp_dept;
      

      建表后, 也是可以继续添加外键的

      -- 添加外键
      ALTER TABLE emp ADD CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES dept(id);