首页 > 数据库 >【MySQL】表的约束

【MySQL】表的约束

时间:2024-12-29 19:28:41浏览次数:3  
标签:示例 MySQL 外键 约束 表中 NULL 主键

表的约束

一、介绍

  • 在MySQL中,表的约束是用于限制表中数据的规则,以确保数据的准确性和一致性。这些约束可以应用于单个列或多个列,也可以在创建表时或修改表时添加。
  • 约束有助于提高数据的完整性和一致性,但过多的约束可能会影响性能。
  • 表的约束的作用是让未来插入数据库表中的数据是符合预期的,即凡是插入进去的数据,都是符合数据约束的。最终目标是保证数据的完整性和可预期性。

二、空属性

1、介绍

  • 在MySQL中,空属性(NULL属性)是表约束和列属性中的一个重要概念,它用于指定某个字段是否可以接受空值(NULL)。它有两个值,分别是NULL和NOT NULL。
  • NULL,表示字段可以接受空值。在MySQL中,默认情况下,字段是允许为NULL的。空值表示字段没有值,它不同于0、空字符串(“”)或其他任何特定值。空值在数据库中通常用于表示未知或未提供的数据。
  • NOT NULL,表示字段不能接受空值。如果尝试将NULL值插入到具有NOT NULL约束的字段中,数据库将拒绝该操作并返回错误。

2、使用场景

  • 数据完整性:通过指定字段为NOT NULL,可以确保该字段在每条记录中都有值,从而维护数据的完整性。
  • 查询优化:在某些情况下,将字段设置为NOT NULL可以提高查询性能。因为数据库引擎在处理非空字段时可能更有效率。
  • 业务逻辑:根据业务逻辑需求,某些字段可能不允许为空。例如,订单表中的订单金额(order_amount)字段通常不允许为空,因为订单金额是订单的必要信息。

3、注意事项

  • 默认值:当字段被设置为NOT NULL且没有提供默认值时,在插入新记录时必须为该字段提供值。否则,数据库将返回错误。
  • 空值运算:在MySQL中,空值(NULL)不参与数学运算、字符串连接等大多数操作。任何与NULL进行的运算结果都将是NULL。
  • 索引和约束:在某些情况下,将字段设置为NOT NULL可能有助于创建索引和约束。例如,主键和唯一约束通常要求字段不能为NULL。

4、示例

CREATE TABLE example_table (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    email VARCHAR(255) NULL
);
  • name字段被设置为NOT NULL,而email字段被设置为NULL。

三、默认值约束(DEFAULT)

  • 在MySQL中,默认值约束(Default Constraint)是一种用于指定字段默认值的规则。当向表中插入新记录而未为该字段指定值时,系统会自动为该字段赋予默认值。
  • 数据类型支持:并非所有数据类型都支持默认值约束。例如,BLOB和TEXT数据类型就不支持默认值约束。
  • NULL值处理:如果字段被设置为允许NULL值(即没有非空约束),并且插入了NULL值,那么默认值将不会被使用。只有当字段没有插入任何值时(包括没有显式插入NULL值),默认值才会被赋予。但default和NOT NULL不冲突,而是互相补充的。
  • 优先级:如果用户为字段指定了具体的值,那么该值将覆盖默认值,即用户指定的值具有更高的优先级。

四、列描述(COMMENT)

1、介绍

  • 在MySQL中,列描述(Column Description)通常指的是对表中各个字段(列)的详细说明和注释。这些描述有助于数据库管理员、开发人员和其他用户更好地理解表结构以及每个字段的用途和含义。即列描述是一种重要的文档化工具,有助于提高数据库的可读性、维护性和易用性。通过合理使用列描述,可以更好地理解和使用数据库表结构。

2、注意事项

  • 描述内容:列描述应简洁明了,避免使用过长或复杂的语句。
  • 一致性:在数据库中,应保持列描述的一致性和准确性,以便于其他用户理解和使用。

3、示例

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五、ZEROFILL

1、介绍

  • ZEROFILL是一种用于在数字字段上进行填充零的属性。通常用于为了确保数字达到指定长度时,左侧用零进行填充。
  • ZEROFILL属性仅影响数字的显示方式,不影响其存储方式。即存储的数据仍然是实际的整数值,只有在检索数据时才会被填充零。
  • 使用ZEROFILL属性时,列的数据类型通常应为整数类型,如INT、SMALLINT、BIGINT等。
  • 如果插入的数字长度超过了指定的显示宽度,MySQL会按照实际长度存储和显示该数字,而不会进行截断。

2、应用场景

  • 标识符填充:在需要保持标识符固定长度的场景下,比如订单编号、产品编号等。
  • 对齐要求:当在表格或报告中需要数字对齐时,ZEROFILL属性可以确保数字始终占据相同的字符宽度。
  • 数据整齐性:用于提高数据整齐性,方便人工查看和处理。

3、示例

create table t12(
a int unsigned,
b int unsigned zerofill
);

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

六、主键约束(PRIMARY KEY)

1、介绍

  • 主键约束是一种用于唯一标识表中每一行数据的约束。它可以确保表中的每一行数据都是唯一的(避免数据重复),并且不允许包含NULL值(因为NULL值无法唯一标识一行数据)。
  • 通常,主键列会设置为自动递增(AUTO_INCREMENT),这样每次插入新行时,主键列的值都会自动增加,无需手动指定,但需要注意AUTO_INCREMENT属性只能用于整数类型的列。
  • 主键约束会自动创建一个唯一索引,以提高查询效率。每个表只能有一个主键约束,但主键约束可以由一个或多个列组成,即联合主键,或称为复合主键。
  • 在数据库设计中,主键通常用于与其他表建立关联关系(外键约束)。

2、语法

CREATE TABLE your_table (
    column1 datatype PRIMARY KEY,
    column2 datatype,
    ...
);

ALTER TABLE your_table
ADD PRIMARY KEY (column1);


CREATE TABLE your_table (
    column1 datatype,
    column2 datatype,
    ...
    PRIMARY KEY (column1, column2)
);

ALTER TABLE your_table
ADD PRIMARY KEY (column1, column2);

3、示例

create table t13(
id int primary key,
name varchar(20)
);

在这里插入图片描述
在这里插入图片描述

alter table t13 drop primary key;
desc t13;

在这里插入图片描述

alter table t13 add primary key(id);
desc t13;

在这里插入图片描述
复合主键

create table t14(
id int,
course_id varchar(10),
name varchar(20),
primary key(id, course_id)
);
desc t14;

在这里插入图片描述
在这里插入图片描述

七、自动递增约束(AUTO_INCREMENT)

1、介绍

  • 自动递增(AUTO_INCREMENT)约束用于在表中生成唯一的数值,通常用于主键(PRIMARY KEY)字段。这个约束确保了每次插入新记录时,该字段的值会自动增加,从而避免了手动插入重复值的问题。
  • 每个表只能有一个AUTO_INCREMENT字段,它通常是整数类型(如INT、BIGINT)。并且,AUTO_INCREMENT字段的值在删除记录后不会重置,除非手动重置。
  • 如果手动为AUTO_INCREMENT字段指定了一个值,该值必须大于当前最大的自动递增值,否则会导致错误。

2、示例

create table t15(
id int unsigned primary key auto_increment,
name varchar(20)
);

insert into t15 (name) values ('薛宝钗');
insert into t15 (name) values ('贾政');

select * from t15;

在这里插入图片描述

  • 添加auto_increment的列不加primary key 时报错

在这里插入图片描述

八、LAST_INSERT_ID

1、介绍

  • LAST_INSERT_ID是MySQL中的一个内置函数,它返回最近一次向具有AUTO_INCREMENT属性的列插入数据时生成的自增ID值。
  • LAST_INSERT_ID函数的返回值是基于每个连接的。这意味着在不同的连接中,调用LAST_INSERT_ID函数将返回不同的值。
  • 如果在一个事务中进行了多次插入操作,那么每次调用LAST_INSERT_ID函数都将返回最后一次插入操作的ID值。
  • 如果在插入操作中没有使用自增主键,那么调用LAST_INSERT_ID函数将返回0。
  • 如果在SQL中显式指定了自增字段的值,那么LAST_INSERT_ID获取到的值将为0。只有当自增字段由MySQL来分配时,LAST_INSERT_ID才能得到正确的值。
  • 若在同一条INSERT语句中插入多行,LAST_INSERT_ID返回的值只是这些行中第一个生成的自增值,而不是所有生成的自增值。

2、示例

  • 本例是在上方示例的基础上执行的。
select last_insert_id();

在这里插入图片描述

desc t15;

在这里插入图片描述

九、唯一约束(UNIQUE)

1、介绍

  • 唯一约束用于保证数据表中字段的唯一性,即表中字段的值不能重复出现。它确保表中特定列的值不重复,如果尝试插入或更新违反唯一约束的数据,数据库会拒绝这些操作并返回错误,从而维护数据的完整性和一致性。
  • 唯一约束允许特定列上存在NULL值。但如果多个空值被视为不同值(在大多数数据库系统中是这样),则它们可以在唯一约束列中共存。
  • 唯一约束可以应用于单个列,也可以应用于多个列的组合。在后者的情况下,只有当多个字段的值都相同时,才视为重复记录。
  • 在某些情况下,表中的主键可能由多列组成。如果某些列的组合能够唯一标识表中的每一行,但不是每一列单独标识行,那么可以使用唯一约束来替代主键。这样可以减少主键的复杂性,提高查询效率。
  • 唯一约束可以加速查询操作,特别是在涉及到唯一约束列的查找或连接时。数据库系统可以利用唯一索引来快速定位满足条件的行。

2、与主键约束的区别

  • 唯一性要求:两者都要求列中的值唯一,但唯一约束允许空值,而主键约束不允许有空值。
  • 索引类型:在默认情况下,主键约束产生聚集索引,而唯一约束产生非聚集索引。聚集索引决定了表中数据的物理存储顺序,而非聚集索引则不改变数据的物理存储顺序。
  • 数量限制:一张表只能有一个主键约束,但可以有多个唯一约束。

3、示例

create table t16(
id int unique key comment '学号',
name varchar(10)
);

desc t16;

在这里插入图片描述
在这里插入图片描述

insert into t16 (name) values('张三');

insert into t16 (id, name) values(12, '李四');

select * from t16;

在这里插入图片描述

十、外键约束(FOREIGN KEY)

1、介绍

  • 外键约束是用来在两个表的数据之间建立链接的一种机制,即在一个表中定义的列,这个列将引用另外一个表中的列。这种关联关系可以确保数据的完整性和一致性。
  • 外键是表的一个字段,不是本表的主键,但对应另一个表的主键。

2、作用

  • 维护数据完整性:外键约束可以确保引用表中的数据与被引用表中的数据之间的一致性,防止引用表中插入无效的引用值。
  • 建立关联关系:外键约束允许在两个表之间建立关联关系,这种关联关系可以用于检索和操作相关联的数据。
  • 防止数据不一致:外键约束可以防止在引用表中删除或更新被引用表中的数据时导致数据不一致的情况发生。

3、创建条件

  • 父表必须存在:对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),且父表必须已经存在于数据库中,或者是当前正在创建的表。
  • 主键和外键数据类型一致:外键列必须与关联表的主键列类型相同。
  • InnoDB存储引擎:两个表必须都使用InnoDB存储引擎,因为外键约束在MyISAM等存储引擎中是不被支持的。

4、类型

  • 单列外键约束:外键关联的字段只有一个,它通常用于建立单一字段的关联关系。
  • 复合外键约束:外键关联的字段有多个,它用于建立多个字段的组合关联关系。
  • 自引用外键约束:一个表中的外键关联到该表中的另一个字段,通常用于表示层次结构关系。
  • 级联外键约束:在外键操作时会自动执行相应的级联操作,如级联删除或更新。

5、注意事项

  • 性能影响:外键约束可能会对性能产生一定影响,特别是在执行大量的插入、更新和删除操作时。
  • 级联操作:当使用级联操作时,要特别小心,确保其不会导致意外的数据删除或更新。
  • 索引维护:外键约束通常需要创建索引来加速引用表的查找操作。这些索引需要维护,因此在插入、更新和删除操作时会导致额外的开销。
  • 命名冲突:如果为外键约束指定了一个名称,请确保该名称在数据库中唯一。

6、语法

(1)语法

CREATE TABLE 子表名 (
    列名1 数据类型 [约束条件],
    列名2 数据类型 [约束条件],
    ...
    [CONSTRAINT 外键约束名] FOREIGN KEY (子表外键列) REFERENCES 父表(父表主键列)
    [ON DELETE {CASCADE | SET NULL | NO ACTION | RESTRICT | SET DEFAULT}]
    [ON UPDATE {CASCADE | SET NULL | NO ACTION | RESTRICT | SET DEFAULT}]
);

ALTER TABLE 子表名
ADD CONSTRAINT 外键约束名 FOREIGN KEY (子表外键列) REFERENCES 父表(父表主键列)
[ON DELETE {CASCADE | SET NULL | NO ACTION | RESTRICT | SET DEFAULT}]
[ON UPDATE {CASCADE | SET NULL | NO ACTION | RESTRICT | SET DEFAULT}];

ALTER TABLE 子表名
DROP FOREIGN KEY 外键约束名;

(2)说明

  • 第一部分为在创建表时定义外键约束,第二部分为在修改表时添加外键约束,第三部分为删除外键约束。
字段意义
子表名要创建的表的名称
列名1…, 列名2…, …表中的列及其数据类型和约束条件
[CONSTRAINT 外键约束名]可选的,为外键约束指定一个名称。如果不指定,MySQL会自动生成一个名称
子表外键列子表中用于建立外键关系的列
父表已经存在的、包含主键的表
父表主键列父表中用于与外键列建立关联的主键列
[ON DELETE {…}]可选的,定义当父表中的行被删除时,子表中的外键列应如何响应
[ON UPDATE {…}]可选的,定义当父表中的主键值被更新时,子表中的外键列应如何响应

7、示例

create table class(
id int primary key,
name varchar(30)
);
create table student(
id int primary key comment '学号',
name varchar(20) comment '姓名',
class_id int comment '班级号',
foreign key (class_id) references class(id)
);

在这里插入图片描述

insert into class values (123, '高一一班');
insert into class values (456, '高二二班');
insert into class values (789, '高三三班';
select * from class;

在这里插入图片描述

insert into student values(147, '贾宝玉', 123);
insert into student values(258, '林黛玉', 789);

在这里插入图片描述

本文到这里就结束了,如有错误或者不清楚的地方欢迎评论或者私信
本文只是在学习过程中所做的总结,不会涉及过深的概念
创作不易,如果觉得博主写得不错,请点赞、收藏加关注支持一下

标签:示例,MySQL,外键,约束,表中,NULL,主键
From: https://blog.csdn.net/Snow_Dragon_L/article/details/144105355

相关文章

  • JAVA连接MYSQL数据库实现查询
    准备驱动(1)查看数据库版本号(2)根据数据库版下载对应版本驱动驱动下载网址:MySQL::DownloadMySQLConnector/J(ArchivedVersions)若没有则选择接近自己版本的低版本。说明:......
  • 【Nginx应用】nginx stream模块代理MySQL
    其实使用开发机器的nginx一样可以代理数据库,从而实现办公网访问数据库。一、stream模块介绍Nginx的TCP/UDP代理功能的模块分为核心模块和辅助模块。核心模块stream需要在编译配置时增加“--with-stream”参数进行编译【但是我测试的时候,我的开发机并不是这么安装的,直接yumiins......
  • 如何正确开启3306端口以允许外部访问MySQL数据库
    问题描述:我正在尝试配置云服务器上的MySQL数据库,使其能够接受来自外部网络的连接请求。但是,当我试图开放3306端口时遇到了困难。请问应该怎样正确地开启这个端口?需要注意哪些事项?解决方案:您好,针对您想要开启3306端口以允许外部访问MySQL数据库的需求,我们整理了一份详细的指南供......
  • 如何解决MySQL数据库导入时出现500错误?
    MySQL数据库在导入过程中出现500错误通常是由于多种原因引起的。以下是详细的排查步骤和解决方案,帮助您顺利导入SQL文件:检查文件大小和服务器配置:如果SQL文件过大,可能会导致超时或内存不足的问题。您可以尝试分批导入较小的SQL文件,或者增加服务器的内存和超时设置。对于较大......
  • emoji在mysql中存储失败的问题(mysql字符集替换)
    mysql字符集需要utf8mb4才能支持emoji存储,因为utf8一个字符最大3字节,但emoji4字节,所以需要升级成真正的UTF-8mysql的uft8最大只有3字节,是因为mysql开发认为3字节足以存储常见字符。后续的uft8mb4(mostbytes4)才是完整的4字节UTF-8修改表及所有字段的默认字符集#修改表及所有......
  • 恢复 MySQL 数据库后小工具无法响应
    在恢复MySQL数据库后,如果遇到小工具无法响应的问题,可能是由于数据库结构或数据完整性受到影响,或者是前端与后端之间的通信出现了问题。以下是详细的排查步骤和解决方案,帮助您恢复小工具的正常功能。确认数据库恢复成功:确保数据库恢复过程顺利完成,所有表和数据均已正确导入......
  • 安装mysql
    vim/etc/my.cnf配置文件如下[mysqld]bind-address=0.0.0.0port=3306#mysql端口号user=rootbasedir=/usr/local/app/mysql#mysql安装目录datadir=/usr/local/app/mysql/data#数据存放目录socket=/tmp/mysql.socklog-error=/usr/local/app/mysql/log/mysqld.log--......
  • mysql下载安装配置以及多版本
    mysql下载安装配置以及多版本1.下载https://downloads.mysql.com/archives/community/点击链接选择ProductVersion(产品版本),操作系统(OperatingSystem)和OSVersion(操作系统版本)点击ZIPArchive行末的Download下载压缩包版本即可,MSIInstaller是安装包版本(一般有压缩包......
  • Mysql索引
    1、什么是索引        索引是数据库中一种特殊存储结构,旨在提高数据检索性能,提高访问速度,且是有序的。InnoDB存储引擎中有主键索引,唯一索引,普通索引,全文索引四类索引。    注意:索引在InnoDB存储引擎中与数据存储在一起的。1.1、主键索引    概......
  • MySQL主从架构
    MySQL主从架构MySQL主从架构(Master-SlaveArchitecture)是一种常见的数据库高可用性和负载均衡的设计模式,通常用于提高系统的可伸缩性和可靠性。它基于数据复制(replication)机制,其中“主”服务器负责处理所有的写操作,而“从”服务器则通过复制主服务器的数据来保持数据一致性,主要用......