MySQL从入门到入土---MySQL表的约束 (内含实践)---详细版

目录

引入:

null 与not null

default:

comment列描述 :

not null 和 default:

zerofill :

主键:primary key

复合主键:

自增长:auto_increment

唯一键:unique key

外键:

引入:

MySQL本质上是数据的最后一道防线,它为了保证自己内部存储的数据一定是符合预期的,会针对每次插入的数据做严格检查,虽然数据类型已经算是一种约束,但是还不够灵活和全面,所以Mysql也存在其他的约束,如:null/not null,default, comment, zerofill,primary 、key,auto_incrementunique key ...

主要介绍null/not null,default, comment, zerofill,primary 、key,auto_incrementunique key 这几种约束。

null 与not null

在实际工程中,大部分情况下一般默认的数据都不会是null,因为没有意义

#新建一张表t1用于测试null
mysql> create table t1(-> class_name varchar(32),-> class_room vaechar(32)-> );#插入测试数据
insert into t1(class_name) values('软件工程');

不插入class_room字段,查一下表中数据:

#查询
select* from t1;

查询结果:

很显然,在教室的数据库表中,class_room不应该出现null,class_name却存在的情况,如果不使用not null修饰,很又可能会发生上述情况,所以给字段属性设置not null后再查一次:

#重新建立表t1
mysql> create table t1(-> class_name varchar(32) not null,-> class_room varchar(32) not null-> );#插入上次测试的数据

显示MySQL不允许此次插入,即要求必须要插入所有数据,不能使用默认的null值。

default:

语法和上述的not nul类似,当字段设置了default约束时,如果插入数据时,该字段对应的数据为null,则默认使用default的值

测试demo:

#创建表用来测试
mysql> create table t2_default(-> class_room varchar(32) not null,-> age tinyint unsigned default 0-> );

insert时,只插入class_room字段:

insert into t2_default values('软件');

查一下:

发现结果确实符合预期,age使用了建表时的默认值;

测试一下字符串:

mysql> create table t3( name varchar(32) default '张三', age int default 0);

 同样的insert一条数据:

mysql> insert into t3 values()-> ;

查一下:

varcahar同样可以使用default,其他类型同理;

comment列描述 :

在创建表时,用来描述字段;

demo测试:

mysql> create table t4(-> age int comment '年龄',-> name varchar(32) comment '姓名'-> );

comment的描述无法使用desc语句查询到,可以使用如下语句查询:

mysql> show create table t4 \G

结果:

符合预期;

not null 和 default:

二者可以连用,但是注意:如果我们建立表的时候两种约束一起使用,例如not null default xxx;

如果我们不在该字段插入数据,只在其余字段插入。是允许插入的;但是如果只设置了not null,MySQL是不允许我们忽略该字段,而直接插入表的其他字段的;

zerofill :

说人话:是MySQL的一种对数据的格式化显示的约束;

当表中字段带有zerofill约束时,数据类型后面的整数才有意义

demo样例,不带zerofill约束:

mysql> create table if not exists t6(-> num int(10) not null-> );

insert一条数据:

mysql> insert into t6 values(5);

查一下:

可以发现不带zerofill约束时,num字段后面带的数字好像并没有体现意义;

加上zerofill约束:

mysql> alter table t6 modify num int(10) zerofill;

再查一次:

 得出结论:如果用户插入的数据合法,但是长度不满足创建表时定义int的显示长度,会补充前导0,直到长度 == 定义表时的int显示长度;当然,字段中一定要携带有zerofill约束,若没携带,则无意义;

补充:zerofill不会改变数据本身意义,只改变显示长度!!

主键:primary key

概念:

  • 主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;
  • 主键所在的列通常是整数类

demo测试:

mysql> create table t7(-> id int not null primary key,-> name varchar(32)-> );

desc查一下:

insert几条数据测试结果:

mysql> insert into t7 values(1,'张三');
mysql> insert into t7 values(1,'李四');
mysql> insert into t7 values(1,'王五');
mysql> insert into t7 values(1,'小明');
mysql> insert into t7 values(1,'小美');

第一次成功插入,但是之后的插入全部被拒绝:

再测试不同的id数据插入:

mysql> insert into t7 values(2,'张三');
mysql> insert into t7 values(3,'张三');
mysql> insert into t7 values(4,'张三');

 查一下:

符合主键的描述,也符合我们的预期;

删除主键:
mysql> alter table t7 drop primary key;

再查一下表结构:

复合主键:

在创建表的时候,在所有字段之后,使用 primary key( 主键字段列表 ) 来创建主键,如果有多个字段
作为主键,可以使用复合主键
直接来个demo测试:
mysql> create table t1(-> id int,-> name varchar(32),-> primary key(id,name)-> );

连续insert2次相同的数据:

mysql> insert into t1 values(1,'张三');

第一次显示成功,第二次拦截;

验证一点:复合主键不允许相同的列组合数据插入;

第二次demo测试:

mysql> insert into t1 values(2,'张三');
mysql> insert into t1 values(3,'张三');
mysql> insert into t1 values(1,'李四');

查一下:

3次均能插入,也就是说,只要组合列中有一列数据与历史已插入数据不同即可;

自增长:auto_increment

auto_increment

来个demo样例:

mysql> create table if not exists t2(-> id int primary key auto_increment comment '学生id',-> name varchar(32)-> );

insert几次数据:

mysql> insert into t2 values(null,'张三');
mysql> insert into t2 values(null,'李四');
mysql> insert into t2 values(null,'王五');

插入成功,并且id全都不重复,如图:

1.auto_increment默认从1开始自增;2.也可以从最近的一次插入的数据(没插入成功的数据一样记录自增)开始自增;3.也可以建表时手动设置初始值

来个demo测试,测试第二点:

mysql> insert into t2 values(100,'王五');
mysql> insert into t2 values(null,'王五');

查一下:

 符合预期;

测试第三点:建表时可以指定auto_increment的初始值:

mysql> create table if not exists t3(-> id int primary key auto_increment,-> name varchar(32)-> )auto_increment=1000;

insert数据:

mysql> insert into t3 values(null,'张三');
mysql> insert into t3 values(null,'李四');

查一下:

 符合预期;

唯一键:unique key

  • 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以 解决表中有多个字段需要唯一性约束的问题。
  • 唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。

来个demo测试:创建一个学生信息表,不允许姓名,电话号码和微信号重复;

mysql> create table student(-> id int unsigned primary key auto_increment comment '学生id',-> name varchar(20) not null unique,-> tel char(20) unique,-> wechat_id varchar(32) unique-> );

desc一下:

insert几次数据测试: 

mysql> insert into student values(null,'张三','123456789','xxxxxx');
mysql> insert into student values(null,'李四','123456789','xxxxxx');
mysql> insert into student values(null,'李四','12345678910','xxxxxx');
mysql> insert into student values(null,'李四','12345678910','xxxxxxyyy');

第一次insert成功,第2,3次失败,第四次成功,查一下表:符合预期;

外键:

  • 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或唯一键约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null

语法:foreign key (字段名) references 主表()

来个案例:需要一张学生表和一张班级表,其中多名学生可以隶属于同一个班级(或者待定),但是不能隶属于班级表中不存在的班级,要删除班级表中的某个班级时,要确保班级中没有学生存在;

测试:

#创建班级表
mysql> create table class(-> id int unsigned primary key auto_increment,-> name varchar(32)-> );#insert班级表数据
mysql> insert into class values(null,'软件工程001');
mysql> insert into class values(null,'软件工程002');#创建学生表
mysql> create table student(-> id int unsigned primary key auto_increment,-> name varchar(32) not null,-> class_id int unsigned,-> foreign key(class_id) references class(id)-> );#insertstudent的有效数据
mysql> insert into student values(null,'张三',1);
mysql> insert into student values(null,'李四',1);
mysql> insert into student values(null,'王五',1);
mysql> insert into student values(null,'赵六',2);
mysql> insert into student values(null,'小王',null);#测试无效数据
mysql> insert into student values(null,'田七',3);
mysql> insert into student values(null,'小明',0);

查一下表中结果:

当插入的学生class_id不在班级表的id中的,显示插入数据失败!

 符合预期;

再测试能否删除主表的数据:

从表数据存在时:

#在主表(班级表)中新增一行信息
mysql> insert into class values(null,'通信工程001');
#此时从表中没有数据是class_id = 3的,我们尝试删除这一行数据
mysql> delete from class where id=3;#测试从表中有数据使用主表的id时能否直接删除
mysql> delete from class where id=1;
mysql> delete from class where id=2;

第一次测试时,可以直接删除,因为主表的id=3在从表中并未有数据使用!

第二次测试时,无法直接删除,因为从表中有数据使用了主表的id:

 符合预期;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/65301.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

易语言 OCR 文字识别

一.引言 文字识别,也称为光学字符识别(Optical Character Recognition, OCR),是一种将不同形式的文档(如扫描的纸质文档、PDF文件或数字相机拍摄的图片)中的文字转换成可编辑和可搜索的数据的技术。随着技…

基于SpringBoot的蜗牛兼职网的设计与实现

一、项目背景 随着社会的快速发展,计算机的影响是全面且深入的。人们生活水平的不断提高,日常生活中人们对蜗牛兼职网方面的要求也在不断提高,需要兼职工作的人数更是不断增加,使得蜗牛兼职网的开发成为必需而且紧迫的事情。蜗牛…

shardingsphere分库分表项目实践5-自己用java写一个sql解析器+完整项目源码

前1节我们介绍了 shardingsphere 分表分库的sql解析与重写: shardingsphere分库分表项目实践4-sql解析&重写-CSDN博客 那么shardingsphere sql 解析底层究竟是怎么实现的呢,其实它直接用了著名的开源软件 antlr . antlr 介绍: ANTLR&a…

光谱相机与普通相机的区别

一、成像目的 普通相机:主要目的是记录物体的外观形态,生成人眼可见的、直观的二维图像,重点在于还原物体的形状、颜色和纹理等视觉特征,以供人们进行观赏、记录场景或人物等用途。例如,拍摄旅游风景照片、人物肖像等…

TiDB 的MPP架构概述

MPP架构介绍: 如图,TiDB Server 作为协调者,首先 TiDB Server 会把每个TiFlash 拥有的region 会在TiFlash上做交换,让表连接在一个TiFlash上。另外 TiFlash会作为计算节点,每个TiFlash都负责数据交换,表连接…

渗透Vulnhub-Solidstate靶机

本篇文章旨在为网络安全渗透测试行业靶机教学。通过阅读本文,读者将能够对渗透Vulnhub系列Solidstate靶机有定的了解 一、信息收集阶段 靶机官网:https://www.vulnhub.com/entry/solidstate-1%2C261/ 因为靶机为本地部署虚拟机网段,查看dhcp…

ElasticSearch - 深入解析 Elasticsearch Composite Aggregation 的分页与去重机制

文章目录 Pre概述什么是 composite aggregation?基本结构after 参数的作用问题背景:传统分页的重复问题after 的设计理念响应示例 after 如何确保数据不重复核心机制Example步骤 1: 创建测试数据创建索引插入测试数据 步骤 2: 查询第一页结果查询第一页返…

两分钟掌握 TDengine 全部写入方式

1. 背景 TDengine 写入过程会涉及很多概念,这些概念目前你是不是还一团乱,参数绑定写入、无模式写入、websocket 写入、RESTFUL 写入 、各种连接器写入等等一堆的写入,都是做什么的,不明白,这里花两分钟时间给你彻底整…

快速理解24种设计模式

简单工厂模式 建立产品接口类,规定好要实现方法。 建立工厂类,根据传入的参数,实例化所需的类,实例化的类必须实现指定的产品类接口 创建型 单例模式Singleton 保证一个类只有一个实例,并提供一个访问他它的全局…

数据可视化echarts学习笔记

目录,介绍 知识储备 一端操作,多端联动的效果(开启了多个网页,操作一端,多个网页的效果会跟着改变) cmd命令控制面板返回上一级或上上级 在当前目录打开文件: cd 文件名 在Windows命令提示符&am…

OpenCV相机标定与3D重建(30)过滤二值图像中的小斑点函数filterSpeckles()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在视差图中过滤掉小的噪声斑点(speckles)。 cv::filterSpeckles 是 OpenCV 库中的一个函数,用于过滤图像或视…

C语言期末复习笔记(中)

目录 五、选择控制结构 1.算法中的概念及描述方法 2.关系运算符和逻辑表达式 3.条件运算符和条件表达式 4.两种多分支if 5.switch语句 6.逻辑运算符和逻辑表达式 六、循环控制结构 1.控制循环的方式 2.控制非法输入 3.选择三种循环的一般原则 4.猜数游戏 5.嵌套循环…

利用Gurobi追溯模型不可行原因的四种方案及详细案例

文章目录 1. 引言2. 追溯不可行集的四种方法2.1 通过约束增减进行判断2.2 通过computeIIS函数获得冲突集2.3 利用 feasRelaxS() 或 feasRelax() 函数辅助排查2.4 利用 IIS Force 属性1. 引言 模型不可行是一个让工程师头疼的问题,对于复杂模型而言,导致模型不可行的原因可能…

MySQL和HBase的对比

Mysql :关系型数据库,主要面向 OLTP ,支持事务,支持二级索引,支持 sql ,支持主从、 Group Replication 架构模型(此处以 Innodb 为例,不涉及别的存储引擎)。 HBase &am…

mybatis-plus自动填充时间的配置类实现

mybatis-plus自动填充时间的配置类实现 在实际操作过程中,我们并不希望创建时间、修改时间这些来手动进行,而是希望通过自动化来完成,而mybatis-plus则也提供了自动填充功能来实现这一操作,接下来,就来了解一下mybatis…

【软件工程】十万字知识点梳理 | 期末复习专用

原创文章,禁止转载。 文章目录 图CRC卡片用例图类图状态图活动图泳道图软件质量因素自顶向下集成自底向上集成人员与工作量之间的关系时序图关键路径软件结构基本路径测试判定表数据流图(DFD)体系结构设计问题数据字典挣值分析等价划分程序流程图PAD | N-S燃尽图甘特图对象模…

STM32完全学习——FLASH上FATFS文件管理系统

一、需要移植的接口 我们通过看官网的手册,可以看到我们只要完成下面函数的实现,就可以完成移植。我们这里只移植前5个函数,获取时间的函数我们不在这里移植。 二、移植接口函数 DSTATUS disk_status (BYTE pdrv /* Physical drive nmuber…

Redis - Token JWT 概念解析及双token实现分布式session存储实战

Token 定义:令牌,访问资源接口(API)时所需要的资源凭证 一、Access Token 定义:访问资源接口(API)时所需要的资源凭证,存储在客户端 组成 组成部分说明uid用户唯一的身份标识time…

软体机器人研究报告:设计方法、材料与驱动、感知与控制

软体机器人因其出色的可变形性和高适应性受到了广泛关注,这些特性使其在医疗、救援、探测等复杂场景中展现出独特的优势和巨大的应用潜力。研究人员对软体机器人的设计方法、材料与驱动技术、感知与控制策略等方面进行深入研究,取得了一系列成果。 本文汇…

imgproxy图像处理的高效与安全

摘要 imgproxy作为一个高效且安全的独立服务器,为图像处理提供了全新的解决方案。它不仅简化了图像调整和转换的过程,还极大地提升了处理速度,确保了整个流程的安全性。通过集成imgproxy,用户可以轻松优化网页上的图像,提高加载速度,改善用户体验。本文将深入探讨imgpro…