文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL数据库表中的约束有哪些

2023-07-05 07:41

关注

这篇文章主要讲解了“MySQL数据库表中的约束有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库表中的约束有哪些”吧!

MySQL表中的约束(constraint)

为了保证数据的完整性,(数据的精确性和可靠性)

SQL规范以约束的方式对表数据进行额外的条件限制,可从以下四个方面进行考虑

约束?对表中字段的限制。

约束分类

约束作用字段的个数

根据约束的作用范围

根据约束起的作用

如何添加约束/删除约束

如何查看表中的约束

SELECT *FROM information_schema.TABLE_CONSTRAINTSWHERE TABLE_NAME='employees';

非空约束

限制某个字段/某列的值不为空

关键字: NOT NULL

添加非空约束

CREATE TABLE test1(id INT NOT NULL,last_name VARCHAR(15) NOT NULL,salary DECIMAL(10,2))
ALTER TABLE test1MODIFY salary DECIMAL(10,2) NOT NULL;

删除非空约束

ALTER TABLE test1MODIFY salary DECIMAL(10,2);

唯一性约束

用来限制某个字段/某列的值不能重复

关键字:UNIQUE

添加唯一性约束

CREATE TABLE test2(id INT UNIQUE, #列约束last_name VARCHAR(15) ,email VARCHAR(25) ,salary DECIMAL(10,2),#表约束CONSTRAINT uk_test2_email UNIQUE(email))

可以项声明未unique的字段上添加null值,而且可以多次添加NULL值

方式一:

ALTER TABLE test2ADD CONSTRAINT uk_test2_salary UNIQUE(salary);

方式二:

ALTER TABLE test2MODIFY last_name VARCHAR(20) UNIQUE;

复合约束

CREATE TABLE `USER`(id INT,name VARCHAR(15),password varchar(25),#表约束实现多行约束CONSTRAINT uk_user_name_pwd UNIQUE(name,password));

create table 表名称(
字段名 数据类型,
字段名 数据类型,
字段名 数据类型,
unique key(字段列表) #字段列表中写的是多个字段名,多个字段名用逗号分隔,表示那么是复合唯一,即多
个字段的组合是唯一的
);

删除唯一约束

ALTER TABLE USERDROP INDEX uk_user_name_pwd;

主键约束

用来唯一标识表中的一行记录

关键字:primary key

主键约束相当于唯一约束+非空约束的组合,主键约束列不允许重复,也不允许出现空值

添加主键约束

CREATE TABLE test3(id INT PRIMARY KEY, #列级约束last_name VARCHAR(15),salary DECIMAL(10,2),email VARCHAR(25));
CREATE TABLE test4(id INT , last_name VARCHAR(15),salary DECIMAL(10,2),email VARCHAR(25),#表约束,没有必要取别名CONSTRAINT pk_test5_id PRIMARY KEY(id));
CREATE TABLE test6(id INT , last_name VARCHAR(15),salary DECIMAL(10,2),email VARCHAR(25));DESC test6;ALTER TABLE test6ADD PRIMARY KEY(id)

复合主键约束

CREATE TABLE test5(id INT , last_name VARCHAR(15),salary DECIMAL(10,2),email VARCHAR(25),#表约束PRIMARY KEY(id,last_name));

删除主键约束

在实际开发中根本不会这样做

ALTER TABLE test6DROP PRIMARY KEY;

自增列-AUTO_INCREMENT

某个字段的值自增

关键字:auto_increment

(1)一个表最多只能有一个自增长列

(2)当需要产生唯一标识符或顺序值时,可设置自增长

(3)自增长列约束的列必须是键列(主键列,唯一键列)

(4)自增约束的列的数据类型必须是整数类型

(5)如果自增列指定了 0 和 null,会在当前最大值的基础上自增;如果自增列手动指定了具体值,直接赋值为具体值。

当向主键(含AUTO_INCREMENT)的字符上添加0或null时,实际上会自动的往上添加指定字段的数值

添加自增约束

开发中,一旦主键作用的字段声明有AUTO_INCREMENT,则我们在添加数据时,就不要给主键赋值了

CREATE TABLE test7(id INT PRIMARY KEY AUTO_INCREMENT, last_name VARCHAR(15),salary DECIMAL(10,2),email VARCHAR(25));
ALTER TABLE test7MODIFY id INT AUTO_INCREMENT;

删除自增约束

ALTER TABLE test7MODIFY id INT

外键约束FOREIGN KEY约束

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

关键字:FOREIGN KEY

主表(父表):被引用的表,被参考的表

从表(子表):引用别人的表,参考别人的表

(1)从表的外键列,必须引用/参考主表的主键或唯一约束的列为什么?因为被依赖/被参考的值必须是唯一的

(2)在创建外键约束时,如果不给外键约束命名,默认名不是列名,而是自动产生一个外键名(例如 student_ibfk_1;),也可以指定外键约束名。

(3)创建(CREATE)表时就指定外键约束的话,先创建主表,再创建从表

(4)删表时,先删从表(或先删除外键约束),再删除主表

(5)当主表的记录被从表参照时,主表的记录将不允许删除,如果要删除数据,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据

(6)在“从表”中指定外键约束,并且一个表可以建立多个外键约束

(7)从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致。如果类型不一样,创建子表时,就会出现错误“ERROR 1005 (HY000): Can’t create table’database.tablename’(errno: 150)”。 例如:都是表示部门编号,都是int类型。

(8)当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是外键的约束名。(根据外键查询效率很高)

(9)删除外键约束后,必须手动删除对应的索引

添加外键约束

创建主表

CREATE TABLE dept1(dept_id INT PRIMARY KEY,dept_num VARCHAR(15))

创建从表

CREATE TABLE emp2(emp_id INT PRIMARY KEY AUTO_INCREMENT,emp_num VARCHAR(15),department_id  INT,CONSTRAINT fk_emp2_dept1_id FOREIGN KEY(department_id) REFERENCES dept1(dept_id))

建表以后添加外键约束

ALTER TABLE emp2ADD fk_emp2_dept1_id FOREIGN KEY(department_id) REFERENCES dept1(dept_id)

约束等级

如果没有指定等级,就相当于Restrict方式。 对于外键约束,最好是采用: ON UPDATE CASCADE ON DELETE RESTRICT 的方式。

删除外键约束

删除外键约束

ALTER TABLE emp2DROP FOREIGN KEY fk_emp2_dept1_id;

删除外键约束对应索引

SHOW INDEX FROM emp2;ALTER TABLE emp2DROP INDEX fk_emp2_dept1_id;

开发场景

问题1:如果两个表之间有关系(一对一、一对多),比如:员工表和部门表(一对多),它们之间是否 一定要建外键约束?

答:不是的

问题2:建和不建外键约束有什么区别?

答:建外键约束,你的操作(创建表、删除表、添加、修改、删除)会受到限制,从语法层面受到限 制。例如:在员工表中不可能添加一个员工信息,它的部门的值在部门表中找不到。

不建外键约束,你的操作(创建表、删除表、添加、修改、删除)不受限制,要保证数据的 引用完整 性 ,只能依靠程序员的自觉 ,或者是 在Java程序中进行限定 。例如:在员工表中,可以添加一个员工的 信息,它的部门指定为一个完全不存在的部门。

问题3:那么建和不建外键约束和查询有没有关系?

答:没有

在 MySQL 里,外键约束是有成本的,需要消耗系统资源。对于大并发的 SQL 操作,有可能会不适合。比如大型网站的中央数据库,可能会因为外键约束的系统开销而变得非常慢 。所以, MySQL 允许你不使用系统自带的外键约束,在 应用层面 完成检查数据一致性的逻辑。也就是说,即使你不 用外键约束,也要想办法通过应用层面的附加逻辑,来实现外键约束的功能,确保数据的一致性。

阿里开发规范

【 强制 】不得使用外键与级联,一切外键概念必须在应用层解决。

说明:(概念解释)学生表中的 student_id 是主键,那么成绩表中的 student_id 则为外键。如果更新学 生表中的 student_id,同时触发成绩表中的 student_id 更新,即为级联更新。外键与级联更新适用于 单 机低并发 ,不适合 分布式 、 高并发集群 ;级联更新是强阻塞,存在数据库 更新风暴 的风险;外键影响 数据库的 插入速度 。

CHECK约束

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

MySQL5.7 可以使用check约束,但check约束对数据验证没有任何作用。添加数据时,没有任何错误或警告

但是MySQL 8.0中可以使用check约束了。

create table employee(eid int primary key,ename varchar(5),gender char check ('男' or '女'));

DEFAULT约束

给某个字段/某列指定默认值,一旦设置默认值,在插入数据时,如果此字段没有显式赋值,则赋值为默认值。

关键字 DEFAULT

建表时

create table 表名称(
字段名 数据类型 primary key,
字段名 数据类型 unique key not null,
字段名 数据类型 unique key,
字段名 数据类型 not null default 默认值,
);

建表后

alter table 表名称 modify 字段名 数据类型 default 默认值;
#如果这个字段原来有非空约束,你还保留非空约束,那么在加默认值约束时,还得保留非空约束,否则非空约束就被删除了
#同理,在给某个字段加非空约束也一样,如果这个字段原来有默认值约束,你想保留,也要在modify语句中保留默认值约束,否则就删除了
alter table 表名称 modify 字段名 数据类型 default 默认值 not null;

删除默认值

alter table 表名称 modify 字段名 数据类型; #删除默认值约束,也不保留非空约束
alter table 表名称 modify 字段名 数据类型 not null; #删除默认值约束,保留非空约束

感谢各位的阅读,以上就是“MySQL数据库表中的约束有哪些”的内容了,经过本文的学习后,相信大家对MySQL数据库表中的约束有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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