【mysql】深入探索mysql中的各种约束条件

ops/2024/10/19 2:23:20/

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:MySQL数据库入门,进阶应用实战必备
景天的主页:景天科技苑

文章目录

  • mysql约束
    • unsigned 无符号
    • not null : 不为空
    • default : 默认值
    • unique: 唯一约束
    • primary key: 主键
    • auto_increment: 自增加一
    • zerofill : 零填充 (配合int使用,不够5位拿0来填充)

mysql_20">mysql约束

mysql中对编辑的数据进行类型的限制,不满足约束条件的报错

unsigned   :    无符号
not null   :       不为空
default    :       默认值
unique     :      唯一值,加入唯一索引
(索引相当于字典目录,索引的提出是为了加快速度,一味地乱加索引不会提高查询效率)
primary key:    主键
auto_increment: 自增加一 ,必须设置了主键才能设置该参数
zerofill   :    零填充
foreign key:    外键

约束在写sql时,放在数据类型的后面,如下,放在int的后面
字段名 类型 约束

unsigned 无符号

create table t3(id int unsigned);
insert into t3 values(-1); error
insert into t3 values(4000000000); success

设置无符号位约束,插入负值就报错
在这里插入图片描述

not null : 不为空

create table t4(id int not null , name varchar(11));
insert into t4 values(1,"张宇");
insert into t4 values(null,"张宇"); error
insert into t4(name) values("李四"); error

设置不为空约束,插入空就报错
在这里插入图片描述

NULL值是处于0和1之间的某个值,他也表示一个值,只不过这个值是NULL值,而不是0。
在进行计算的时候,1与NULL则结果为NULL。而0与NULL则结果为0。
1或NULL则结果为1,0或NULL则结果为NULL;可见NULL值是介于0和1之间的值。
另外非NULL既不是1也不是0,还是NULL

default : 默认值

create table t5(id int not null  , name varchar(11) default "沈思雨" );
insert into t5 values(1,null);
insert into t5(id) values(2);

设置了默认值后,插入时填入值,就是设置的值,非全列插入时,不写该字段的值,就用默认值
在这里插入图片描述

create table t5_2(id int not null  default "1111" , name varchar(11) default "沈思雨" );
insert into t5_2 values(); # 在values里面不写值,默认使用默认值;

在这里插入图片描述

unique: 唯一约束

加入唯一索引(索引的提出是为了加快速度,一味地乱加索引不会提高查询效率,索引是有一个文件来存索引)
唯一 可为null 标记成: UNI

create table t6(id int unique , name char(10) default "赵万里" );
insert into t6(id) values(1);
insert into t6(id) values(1); error
insert into t6(id) values(null);
insert into t6(id) values(null); # id变成了多个null

如果要删除null的字段,可以用 where 字段 is null 来删
唯一性约束,可以有多个null值,不违背唯一性约束
在这里插入图片描述

primary key: 主键

[ 唯一 + 不为null ] PRI 标记数据的唯一特征
一个表中,只能设置一个字段为一个主键,unique唯一约束可以设置多个
创建主键

create table t7(id int primary key , name varchar(10) default "赵沈阳");
insert into t7(id) values(1);
insert into t7(id) values(1); error 
insert into t7(id) values(null); error

设了主键,该字段不能重复,不能为空
在这里插入图片描述

unique + not null => PRI

create table t8(id int unique not null ,  name varchar(10) default "赵沈阳" );

设置了唯一性约束,且不为null,功能就跟primary key一样了
在这里插入图片描述

如果没有设置primary key,设置了unique not null ,默认把unique +not null 设置的字段设为主键
在这里插入图片描述

primary key / unique + not null => 优先把primary key 作为主键;

create table t9(id1 int unique not null ,  id2 int primary key );

同时设置了unique +not null 和 primary key 。优先把primary key 作为主键
在这里插入图片描述

一个表只能设置单个字段为一个主键;

create table t10(id1 int  primary key  ,  id2 int primary key ); error

在这里插入图片描述

auto_increment: 自增加一

一般配合 主键或者unique 使用

create table t11(id int primary key auto_increment , name varchar(255) default "敬文栋");
insert into t11 values(1,"张三");
insert into t11 values(null,"李四");
insert into t11(id) values(null);
# 使用默认值或者自增插入数据
insert into t11 values();

在这里插入图片描述

删除数据,这是删除所有数据
delete from t11;
删除数据 + 重置id
truncate table t11;

主键自增,可以用0,null,default占位
在这里插入图片描述
在这里插入图片描述

删除一条数据后,如果再添加不想主键从下一个开始,需要在添加之前,复位主键
删除数据后,执行下面的sql

如果是中途删除,先查看一下目前的auto_increment

show create table student;| student | CREATE TABLE `student` (`id` int NOT NULL AUTO_INCREMENT,`name` varchar(20) NOT NULL,`age` int NOT NULL,`birthday` date DEFAULT NULL,`is_del` tinyint DEFAULT '0',`height` decimal(3,2) DEFAULT NULL,`cls_id` varchar(6) NOT NULL,PRIMARY KEY (`id`),KEY `fk_class` (`cls_id`),CONSTRAINT `fk_class` FOREIGN KEY (`cls_id`) REFERENCES `class` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=20 DEFAULT CHARSET=utf8 |

AUTO_INCREMENT=几 下次插入时就从几开始递增

ALTER TABLE (表名) AUTO_INCREMENT = 1;
在这里插入图片描述

zerofill : 零填充 (配合int使用,不够5位拿0来填充)

create table t12(id int(5) zerofill);
insert into t12 values(1234567);

位数超了之后,按写入的数据直接插入
在这里插入图片描述

insert into t12 values(12);

位数不足,前面补0
在这里插入图片描述


http://www.ppmy.cn/ops/34283.html

相关文章

Linux(openEuler、CentOS8)基于chrony企业内网NTP服务器搭建实验

一、知识点 chrony 是由 守护进程 chronyd 以及 命令行工具 chronyc 组成的 chronyd 在后台静默运行并通过 123 端口与时间服务器定时同步时间,默认的配置文件是 /etc/chrony.conf chronyc 通过 323 端口与 chronyd 交互,可监控 chronyd 的性能并在运…

《QT实用小工具·五十六》自适应界面变化的控件

1、概述 源码放在文章末尾 该项目实现了网格显示多张带文字的图片在界面中自适应布局 特点 跟随窗口大小变换位置,并带移动动画 响应鼠标事件,图片缩放动画 点击水波纹动画 项目demo演示如下所示: 项目部分代码如下所示: #i…

Amine-PEG-Amine,956496-54-1在生物成像、生物传感器等领域具有广泛的应用

【试剂详情】 英文名称 Amine-PEG-Amine,NH2-PEG-NH2 中文名称 氨基-聚乙二醇-氨基,氨基PEG氨基, 双端氨基聚乙二醇 CAS号 956496-54-1 外观性状 由分子量决定,液体或者固体 分子量 0.4k,0.6k,1k&…

git--.gitignore--使用/详解/实例

简介 本文介绍git的.gitignore忽略文件的用法。 项目中并不是所有文件都需要保存到版本库中的,例如“target”目录及目录下的文件就可以忽略。 忽略某个文件(不提交到版本库的方法):在Git工作区的根目录下创建一个.gitignore文件…

技术叠加特性之下的中国大模型应用优势

在底层竞争上,中国的能力还有待提升。只要把握住应用的这个关键,尊重科技的市场规律,突破就是水到渠成的事。如果一味实施全面赶超战略,反而可能欲速则不达。 9月7日,腾讯混元大模型在2023腾讯全球数字生态大会上正式…

IDEA--debug

1. 单点调试的三个级别 Step into:在单步执行时,遇到子函数就进入并且继续单步执行。Step over:在单步执行时,在函数内遇到子函数时不会进入子函数内单步执行,而是将子函数整个执行完再停止,也就是把子函数…

大数据信用风险特别高,那大数据信用高风险要如何降低呢?

在大数据信用报告中,综合评分是直观体现信用风险高低的重要元素,也就是我们长听说的大数据信用分,很多人在查大数据信用报告之后,发现自己的大数据信用风险特别高,那大数据信用高风险要如何降低呢?小编从引起高风险的…

Vue 组件通信

Vue 组件间通信可以通过多种方式实现,具体方法包括: 1. **Props**:适用于父组件向子组件传递数据。子组件通过props选项接收数据,这种方式是单向的,主要用于传递静态数据或配置信息。 2. **Events($emit/$…