13_MySQL中的约束(一)

简介: 13_MySQL中的约束(一)

1. 约束(constraint)概述


1.1 为什么需要约束


数据完整性(Data Integrity)是指数据的 精确性 (Accuracy)和 可靠性 (Reliability)。它是防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而提出的。 为了保证数据的完整性,SQL 规范以约束的方式对 表数据进行额外的条件限制 。从以下四个方面考虑:

实体完整性( Entity Integrity ) :例如,同一个表中,不能存在两条完全相同无法区分的记录

域完整性( Domain Integrity ) :例如:年龄范围 0-120 ,性别范围 “ 男 / 女 ”

引用完整性( Referential Integrity ) :例如:员工所在部门,在部门表中要能找到这个部门

用户自定义完整性( User - defined Integrity ) :例如:用户名唯一、密码不能为空等,本部门经理的工资不得高于本部门职工的平均工资的5 倍。


1.2 什么是约束


约束是表级的 强制规定 。

可以在 创建表时规定约束(通过 CREATE TABLE 语句) ,或者在 表创建之后通过 ALTER TABLE 语句规定 约束 。


1.3 约束的分类


根据约束数据列的限制,约束可分为:

单列约束:每个约束只约束一列

多列约束:每个约束可约束多列数据

根据约束的作用范围,约束可分为:

列级约束:只能作用在一个列上,跟在列的定义后面

表级约束:可以作用在多个列上,不与列一起,而是单独定义

                  位置                       支持的约束类型                             是否可以起约束名

列级约束: 列的后面                语法都支持,但外键没有效果       不可以

表级约束: 所有列的下面         默认和非空不支持,其他支持       可以(主键没有效果)

根据约束起的作用,约束可分为:

NOT NULL 非空约束,规定某个字段不能为空

UNIQUE 唯一约束,规定某个字段在整个表中是唯一的

PRIMARY KEY 主键(非空且唯一)约束

FOREIGN KEY 外键约束

CHECK 检查约束

DEFAULT 默认值约束

注意:MySQL不支持check约束,但可以使用check约束,而没有任何效果

查看某个表已有的约束


#information_schema数据库名(系统库)
#table_constraints表名称(专门存储各个表的约束)
SELECT * FROM information_schema.table_constraints
WHERE table_name = '表名称';


SELECT * FROM information_schema.table_constraints
WHERE table_name = 'employees';


5d7614b59b99ff47b6486e7ec719a632_41f5a68b5f8b4c3e8d5aaa79328deb75.png


2. 非空约束


2.1 作用


限定某个字段 / 某列的值不允许为空


fc1b00898c332b9e879ffb5a7d110320_38cdb607d2a642929e0e4257da4860d9.png


2.2 关键字


NOT NULL


2.3 特点


默认,所有的类型的值都可以是NULL,包括INT、

FLOAT等数据类型

非空约束只能出现在表对象的列上,只能某个列单独限定非空,不能组合非空

一个表可以有很多列都分别限定了非空

空字符串''不等于NULL,0也不等于NULL


2.4 添加非空约束


(1)建表时


CREATE TABLE 表名称(
字段名 数据类型,
字段名 数据类型 NOT NULL,
字段名 数据类型 NOT NULL
);


(2)建表后


alter table 表名称 modify 字段名 数据类型 not null;


2.5 删除非空约束


alter table 表名称 modify 字段名 数据类型 NULL;#去掉not null,相当于修改某个非注解字段,
该字段允许为空
alter table 表名称 modify 字段名 数据类型;#去掉not null,相当于修改某个非注解字段,
该字段允许为空


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
4月前
|
存储 安全 关系型数据库
MySQL数据库约束条件概述及其重要性讨论。
正确地实现并管理好各类紧缩条件将直接影响到企业信息管理水平与服务质量,在当今大数据背景下更显得格外重要;任何设计师都需要深刻理解其原理与运作机晰承担起责任使得所托管资料安全稳固同时又具备良好伸缩灵活度迎合日益复杂商务需求变动.
185 11
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
关系型数据库 MySQL
MYSQL:约束(主键约束)
MYSQL:约束(主键约束)
|
12月前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
183 1
|
12月前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
182 4
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
262 1

推荐镜像

更多