文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SQL语句 -非空约束 - 唯一约束 - 主键约束 - 默认约束 -外键约束

2023-08-17 09:00

关注

约束介绍和分类

约束的概念:

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

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

约束的分类如下:

约束名称描述关键字
非空约束保证列中所有数据不能有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;

案例练习

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

在这里插入图片描述

语句演示:

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主键;

在这里插入图片描述

创建部门表(注意要先创建部门表), 将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);

来源地址:https://blog.csdn.net/m0_71485750/article/details/127796631

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯