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

在这里插入图片描述

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

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

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,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约束

在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.mzph.cn/diannao/6886.shtml

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

相关文章

Java | Spring框架 | Bean的装配之XML配置

Spring | Bean的装配 之XML配置 在Spring框架中,Bean的装配是指将Bean定义和配置信息加载到Spring容器中,以便容器能够管理这些Bean。 Spring支持多种装配方式,其中XML配置是传统但依然有效的方式。 一、 使用XML配置文件定义Bean XML配置…

16、Python:函数定义

Python中的函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。它们能提高代码的模块性,和代码复用率。你可以将功能性代码块定义为函数,并在需要时调用它们。 函数定义 在Python中,def关键…

知识图谱和大语言模型的共存之道

导读 知识图谱和大型语言模型都是用来表示和处理知识的手段。大模型补足了理解语言的能力,知识图谱则丰富了表示知识的方式,两者的深度结合必将为人工智能提供更为全面、可靠、可控的知识处理方法。在这一背景下,OpenKG组织新KG视点系列文章—…

构建第一个ArkTS应用之@管理应用拥有的状态概述

上一个章节中介绍的装饰器仅能在页面内,即一个组件树上共享状态变量。如果开发者要实现应用级的,或者多个页面的状态数据共享,就需要用到应用级别的状态管理的概念。ArkTS根据不同特性,提供了多种应用状态管理的能力: …

还有谁……想知道“线下与线上布局之间的本质区别”

还有谁……想知道 线下与线上布局之间的本质区别 hello,亲爱的你们好.… 我是你们的好朋友,正博,今天是非常特殊的一天,给每一位读者准备了一份特殊的神秘礼物…… 在分享【特殊礼物】之前,请允许我分享一下《线下营销与线上销售的9大核心差异》…… 1、注意力; 2、销…

浪漫编码:手把手教你实现校园表白墙功能

💓 博客主页:从零开始的-CodeNinja之路 ⏩ 收录文章:浪漫编码:手把手教你实现校园表白墙功能 🎉欢迎大家点赞👍评论📝收藏⭐文章 这里写目录标题 表白墙数据准备引入MyBatis和MySQL驱动依赖…

音视频开发2 音频基础

基本概念 三巨头:采样率、采样格式,声道数与声道布局、 PCM、音质、音频编码格式、音频封装格式 采样率: 每秒采集的样本数量 我们知道声音是连续的一段波, 模拟信号的波形是无限光滑的,可以看成由无数个点组成&am…

华为OD机试【路灯照明问题】(java)(100分)

1、题目描述 在一条笔直的公路上安装了N个路灯,从位置0开始安装,路灯之间间距固定为100米。 每个路灯都有自己的照明半径,请计算第一个路灯和最后一个路灯之间,无法照明的区间的长度和。 2、输入描述 第一行为一个数N&#xff…

中霖教育:哪些地区的一级造价师考试不查社保?

关于一级造价师考试是否查社保的问题,不同地区的规定不一样,部分地区要求社保缴纳时间为1年,部分地区要求6个月,具体还要以资格审核为准。 不用查社保的省份: 江苏、浙江、广东、海南、吉林、黑龙江、内蒙古、山西、…

生信软件16 - 常规探针设计软件mrbait

1. mrbait安装 mrbait支持linux和macOS系统,测试安装Python版本 3.6.15。 # conda安装 conda install mrbait -c tylerkchafin -c bioconda -c conda-forge# github安装 git clone https://github.com/tkchafin/mrbait.git cd mrbait python ./setup.py install# …

Oracle 23ai 发布,国产数据库们都沉默了

几天前,全球最大的数据库软件公司 Oracle 发布了最新版的 Oracle Database 23ai ,集成了最新的 AI Vector Search(AI 向量搜索引擎),允许根据概念内容轻松搜索存储在任务关键型数据库中的文档、图像和关系数据&#xf…

一文学会最强大的 node.js 后端框架 nest.js

文章目录 nest cli项目基本结构IOC & DI基础注册值注册时 key 的管理动态注册类工厂函数方式注册设置别名导出 provider 模块功能模块模块的导入导出模块类中使用注入全局模块动态模块 中间件定义中间件注册中间件MiddlewareConsumer 类全局中间件 异常过滤器抛出异常自定义…

社交媒体数据恢复:batchat

蝙蝠聊天数据恢复方法 1. 数据恢复的基本原理 蝙蝠聊天的聊天记录一旦删除是不能够恢复的。这是因为蝙蝠聊天的聊天记录是保存于本地的,一旦删除,就如同在电脑或手机上删除文件一样,数据不会存储在服务器端。这意味着,如果你删除…

vue computed的缓存在哪里

在 Vue 中,计算属性的缓存存在于计算属性本身所属的组件实例中。 具体来说,缓存是作为组件实例的一部分而存在的,在组件被销毁时,缓存也会随之被销毁。 当组件实例被创建时,Vue 会为每个计算属性创建一个闭包&#x…

10.k8s的附加组件(coreDNS组件)

目录 一、概念 二、查看k8s集群的coreDNS的IP地址 三、验证 一、概念 service发现是k8s中的一个重要机制,其基本功能为:在集群内通过服务名对服务进行访问,即需要完成从服务名到ClusterIP的解析。k8s主要有两种service发现机制:…

v-show和v-if的区别

首先,在用法上的区别: v-show是不支持template; v-show不可以和v-else-起使用; 其次,本质的区别: v-show元素无论是否需要显示到浏览器上,它的DOM实际都是有渲染的,只是通过CSS的dis…

【AI+音视频总结】如何在几分钟内用智能工具摘取音视频精华?揭秘下一代学习和内容创作神器!

今天无意发现一个网站,可以一步到位完成AI音视频总结。 我之前对于音视频总结的步骤还是借助 工具下载 剪映来完成的。详情可以参考之前写的一篇文章 【AI应用】模仿爆款视频二次创作短视频操作步骤 。 这里介绍的网站是 BibiGPT 。 BibiGPT AI 音视频助理 - 它是…

举个栗子!Minitab 技巧(8):用 PLS 偏最小二乘分析大豆脂肪影响因素

在上一个 🌰 中,我们用 Minitab 最小二乘法验证了两个变量(单位桶数与运输时间)之间是否存在某种关系。那么,在更复杂的场景中,如何验证一组预测变量和一个或多个连续响应变量之间的关系? 假设…

岩土工程监测中振弦采集仪的布设方案及实施步骤简析

岩土工程监测中振弦采集仪的布设方案及实施步骤简析 岩土工程监测中,河北稳控科技振弦采集仪是一种常用的地下水位和土层压缩性监测工具。它通过采集振弦的振动信号来确定地下水位和土层的压缩性,为岩土工程的设计、施工和监测提供重要的数据支持。下面…

产品AB测试设计

因为vue2项目升级到vue3经历分享1,vue2项目升级到vue3经历分享2,前端系统升级,界面操作也发生改变,为了将影响降到最低,是不能轻易让所有用户使用新系统的。原系统使用好好的,如果新界面用户不喜欢&#xf…