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.rhkb.cn/news/498074.html

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

相关文章

linux安装nginxs报错:openssl not found

系统: linux 版本:centOS7 nginx版本:nginx-1.20.2 linux安装nginx时 执行下面命令时报错: ./configure --with-http_stub_status_module --with-http_ssl_module --prefix/usr/local/nginxchecking for OpenSSL library ... not …

Flutter:打包apk,详细图文介绍

困扰了一天,终于能正常打包apk安装了,记录下打包的流程。建议参考我这篇文章时,同时看下官网的构建说明。 官网构建并发布 Android 应用详情 1、AS创建Flutter项目 2、cmd执行命令 生成一个sunluyi.jks的文件,可以自行把sunluyi替…

shell命令以及运行原理

目录 一、命令解释器 1、什么是命令行解释器 shell和bash联系 2、为什么用命令行解释器 作用 存在意义 二、Linux权限 1、用户分类 2、Linux权限管理 1)权限身份 2)文件类型和访问权限 3)文件访问权限的相关设置方法 a. chmod …

精准识别花生豆:基于EfficientNetB0的深度学习检测与分类项目

精准检测花生豆:基于EfficientNet的深度学习分类项目 在现代农业生产中,作物的质量检测和分类是确保产品质量的重要环节。针对花生豆的检测与分类需求,我们开发了一套基于深度学习的解决方案,利用EfficientNetB0模型实现高效、准…

CSS利用浮动实现文字环绕右下角,展开/收起效果

期望实现 文字最多展示 N 行,超出部分截断,并在右下角显示 “…” “更多”; 点击更多,文字展开全部内容,右下角显示“收起”。效果如下: 思路 尽量使用CSS控制样式,减少JS代码复杂度。 利…

FOC控制原理-HALL传感器测量电角度

0、相关文章 【电机控制算法】基于霍尔位置传感器(HALL)估算连续电角度(基于STM32F407CubeMXHAL)_峰岹hall-CSDN博客 电机控制【FOC】_SimpleFOC_通过 Hall 计算电机角度和速度原理 - 大大通(简体站) (wpgdadatong.com.cn) STM32 FOC SDK2.0中使用hall传…

手机实时提取SIM卡打电话的信令声音-智能拨号器的SIP线路-双卡双待单通方案

手机实时提取SIM卡打电话的信令声音 --智能拨号器的SIP线路-双卡双待单通方案 一、前言 蓝牙电话的技术方案最初是从蓝牙耳机和车机蓝牙的使用领域延伸出来的技术方式。通过蓝牙的HFP协议,把手机通话的声音和通话事件状态提取出来进行复用和处理。但中国大陆现行…

C++--类与对象

1.封装 封装是c面向对象的三大特性之一 将属性和行为作为一个整体 将属性和行为加以权限控制 语法: class 类名{ 访问权限: 属性/行为 }; 访问权限 public 公共权限 类内类外均可以访问 protected 保护权限 类内可以访问,类外不可以访问 pr…

遗传算法与深度学习实战(29)——编码卷积自编码器架构

遗传算法与深度学习实战(29)——编码卷积自编码器架构 0. 前言1. 构建卷积自编码器2. 构建卷积自编码器基因序列3. 解析基因序列构建模型小结系列链接 0. 前言 使用遗传算法 (Genetic Algorithm, GA) 构建自编码器 (AutoEncoder, AE) 优化器时&#xff…

蓝桥杯(Java)(ing)

Java前置知识 输入流: (在Java面向对象编程里面有提过相关知识) // 快读快写 static BufferedReader in new BufferedReader(new InputStreamReader(System.in)); static BufferedWriter out new BufferedWriter(new OutputStreamWriter…

Ajax数据爬取

有时我们用requests 抓取页面得到的结果,可能和在浏览器中看到的不一样:在浏览器中可以看到正常显示的页面数据,而使用requests 得到的结果中并没有这些数据。这是因为 requests 获取的都是原始 HTML 文档,而浏览器中的页面是JavaScript 处理…

tcpdump 网络数据包分析工具

简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具。 tcpdump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的…

手机发烫怎么解决?

在当今这个智能手机不离手的时代,手机发烫成了不少人头疼的问题。手机发烫不仅影响使用手感,长期过热还可能损害手机硬件、缩短电池寿命,甚至引发安全隐患。不过别担心,下面这些方法能帮你有效给手机 “降温”。 一、使用习惯方面…

BUUCTF Pwn ciscn_2019_es_2 WP

1.下载 checksec 用IDA32打开 定位main函数 发现了个假的后门函数: 看看vul函数: 使用read读取 想到栈溢出 但是只有48个 只能覆盖EBP和返回地址 长度不够构造 所以使用栈迁移: 栈迁移需要用到leave ret 使用ROPgadget找地址: …

IEDA 使用auto Dev编码助手配置Deep Seek V3

文章目录 API Key的申请和创建auto Dev的下载auto Dev的安装Deep seek V3的连接配置和注意事项错误解决:You LLM server Key is empty API Key的申请和创建 登陆Deep Seek开放平台,创建API Key 并复制 auto Dev的下载 auto Dev项目地址,发…

vue3学习笔记(6)-生命周期、hooks

1.生命周期 <template><div><div>{{ a }}</div><div click"test"></div></div> </template> <script setup lang"ts" name"hi"> import { ref, onBeforeMount, onMounted, onBeforeUpdat…

#端云一体化开发# #HarmonyOS Next#《说书人》鸿蒙原生基于角色的对话式文本编辑开发方案

1、写在前面 过去的一百年里&#xff0c;在“编程”的这个行业诞生之初&#xff0c;人们采用面向过程的方式进行开发&#xff0c;但是&#xff0c;伴随着程序规模的日益增大&#xff0c;程序的复杂度也随之增加&#xff0c;使用结构化编程方法来管理复杂的程序逻辑变得越来越困…

【ELK】ES单节点升级为集群模式--太细了!

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言准备工作1. 查看现状【单节点】2. 原节点改集群模式3. 改es配置文件&#xff0c;增加集群相关配置项4. *改docker映射的端口* 启动新节点5. docker-compose起一…

Python跨年烟花

目录 系列文章 写在前面 技术需求 完整代码 下载代码 代码分析 1. 程序初始化与显示设置 2. 烟花类 (Firework) 3. 粒子类 (Particle) 4. 痕迹类 (Trail) 5. 烟花更新与显示 6. 主函数 (fire) 7. 游戏循环 8. 总结 注意事项 写在后面 系列文章 序号直达链接爱…

未来网络技术的新征程:5G、物联网与边缘计算(10/10)

一、5G 网络&#xff1a;引领未来通信新潮流 &#xff08;一&#xff09;5G 网络的特点 高速率&#xff1a;5G 依托良好技术架构&#xff0c;提供更高的网络速度&#xff0c;峰值要求不低于 20Gb/s&#xff0c;下载速度最高达 10Gbps。相比 4G 网络&#xff0c;5G 的基站速度…