数据库之约束、索引和事务
一、约束
约束,顾名思义就是数据库对数据库中的数据所给出的一组检验规则.负责判断元素是否符合数据库要求.其目的就是为了提高效率以及准确性.
1.not null - > 数据元素非空
表示如果插入数据,则当前数据不能为空.
//创建一张学生表,其班级id和年级id不为空
create table student (id int not null ,name varchar(20) ,gender varchar(5) ,class_id int not null) ;
2.unique - > 让列的值唯一
表示所约束的此列,值不能重复,必须唯一
//创建一个学生表,其id不为空
create table studnet (id int unique ,name varchar(20));
3.default - > 让列具有默认值
表示如果插入一行而指定列未插入时,默认初始化
//建立一个珠宝表,如果价值未告诉,默认其未无价之宝
create table jewelry(name varchar(20) ,price varchar(200) default '无价之宝') ;
4. primary key - > 主键
对主键的要求就是唯一并且不能为空
MySQL中对主键的要求就是表里只能有一个主键,并且不能为空
虽然只能有一个主键,但是可以以一列作为主键,也可以以多列作为主键.
//创建一个学生表,其id不能为空,且不能重复
create table student(id int primary key ,name varchar(5)) ;
拓展:自增主键
给自增主键插入数据的时候,可以手动插入一个值,也可以让MySQL自动分配
如果要自动分配,那么插入值时标记为null即可
并且在自动分配时,系统给定值一定比所有值的最大值还要大
//创建一个学生表,其id为自增主键
create table student (id int primary key auto_increment ,name varchar(20)) ;
5.foreign key - > 外键
顾名思义:外键应该是两张表进行联合
外键的写法:一个表中非主键的字段指向另一张表主键的字段
当更改父表和子表时,如果约束关系不成立,那么就不能进行更改:
对于父表来说,不能删除和修改
对于子表来说:不能修改或新增
上述都是建立在约束关系不成立的基础上
如果增删查改时约束关系成立,那么就可以进行
//创建一张班级表和学生表//带有主键的班级表
create table class(classid int primary key auto_increment ,className varchar(20)) ;//其中表示此表的classid和班级表的classid构成约束关系
create table student(id int ,name varchar(20) ,classid int, foreign key (classid) references class(classid)) ;
二 、索引
索引就是给数据库增加一个目录
其目的就是增快查询速度,带来的坏处就是占用空间增多
虽然查询速度增快,但是修改,删除,插入的速度就会减慢
但是整体来说,利大于弊.毕竟在工作过程中,查询频率是最高的.
1.查看索引
show index from class ;
2.创建索引
create index index_stduent_name on student(name) ;
3.删除索引
drop index index_student_name on student ;
4.索引背后的数据结构 - > B+树(一般都是面试常考)
运用了树的结构
不使用二叉搜索树的原因:如果树的元素变多了,那么树的高度就会变高,树的高度就相当于访问次数,对于数据库来说,数据是存在硬盘当中的,每访问一次硬盘,时间效率是巨大的,因此不采用二叉搜索树
不使用哈希表的原因:虽然哈希查询的快,但是不支持范围查询,不支持模糊匹配,从而不使用哈希表来进行查询
先了解B树,也就是所谓的B-树
B树可以认为是一个N叉搜索树,当节点的子树多了,节点上保存的key多了,意味着在同样key个数的前提下:B树的高度就要比二叉搜索树低很多,树的高度越高,进行查询时访问磁盘的次数就越多
B+树是在B树的基础上又做出改进(也是N叉搜索树)
右值就是其最大值,而B树则可能比右值还大(两树的唯一区别)
特点:一个节点可以存储N个key , N个key划分出了N个区间
每个节点中Key的值,都会在子节点中出现,并且key是子节点的最大值
B+树的叶子节点是首尾相连,类似于一个链表,因此整个树的所有数据都是包含在叶子节点中的(所有非叶子节点key值最终都会出现在叶子节点中)
由于叶子节点,是完整的数据集合,只在叶子节点这里存数据表的每一行记录,
而非叶子节点,只存key值本身即可
B+树的优势
当一个节点保存更多的key,最终树的高度是相对更矮的,查询的时候减少了IO访问次数(和B树一样)
所有的查询结果最终都会落到叶子节点上(查询任何一个数据,经过的IO访问次数,是一样的)
B+树所有的叶子节点构成链表,此时比较方便进行范围查询
由于数据都在叶子节点上,非叶子节点只能存储key.导致非叶子节点占用的空间是比较小的,这些非叶子节点就可以在内存中缓存(或者缓存一部分),又进一步减少了IO的次数
MySQL组织数据的形式,当你看到一张表的时候
实际上这个表不一定就是按照表格的这样的数据结构在硬盘上组织的
也有可能是按照这种树形结构组织的
具体是那种结构,取决你表里有没有索引,以及数据库使用了哪种存储引擎
如果有多个索引
假设有一个主键索引,还有一个索引
那么,首先还是构建一个主键索引,然后,针对另一个索引,又会创建另外一个B+树
但是这个叶子节点不是存储其索引的值,而是主键索引的值
如果根据索引来查询,查到的是主键索引的值,然后再查询一次主键索引
从而得到结果
上述过程称为回表,都是由MySQL自动完成的,用户察觉不到
三、事务
在日常生活中,我们进行转账时,对方进行转账,我接受转账,让双方都成功时,转账才算成功
事务就是如此,将多个SQL语句打包成一个整体,如果成功,那么都所有语句都会执行完毕;如果失败,那么所有语句都不会执行.在数据库进行操作的过程中失败以后,也不是真正的没有执行,而是将执行过的语句回滚,从而恢复现场.
如何回滚?数据库中有专门用来记录事务的日志.因此,当使用事务时,SQL语句使用的开销是更大的,效率也是更低的.
开启事务
//开始事务,从此语句之后的所有语句都要打包执行
strat transaction ;//结束事务,当此语句执行后,事务执行完毕
commit
事务的特性
原子性(最核心的特性)
一致性(类似于转账)
持久性(数据库的内容都是写在硬盘上的,从而具有长期保存性)
隔离性('并发'执行事务引起的问题)
所谓并发:服务器同时处理多个客户端的请求
如果客户端所给服务器发的事务,作用的不是同一个表/数据,那么一般不会出现问题;如果是作用于同一个表/数据,那么极有可能出现问题
对于并发执行事务可能产生的问题
1.脏读问题(脏指的是读到的数据是无效数据)
一个事务正在对数据进行修改的过程中,还没提交之前
另外一个事务,对同一个数据进行了读取
此时,读取数据的事务的操作就称为”脏读”,读到的数据也是”脏数据”
如何解决
MySQL引入”写操作加锁”这样的机制(也就是写的时候不能读)
这个操作,降低了并发程度(也就是降低了效率),但是提高了隔离性(提高了数据的准确性)
2.不可重复读
事务1已经提交了数据,事务2开始去读取数据
读取过程中,事务3又提交了新的数据
此时意味着同一个事务2之内,多次读数据,读出来的结果是不相同的
(预期是一个事务中,多次读取的结果是相同的)
如何解决
MySQL引入”给读操作加锁”这样的机制(也就是读的时候,不能写)
这个操作,又进一步降低了事务的并发处理能力(处理效率降低)
提高了事务的隔离性(数据的准确性又增加了)
3.幻读
已经约定了读加锁和写加锁,解决了不可重复和脏读问题
在读加锁和写加锁的前提下,一个事务两次读取同一个数据
发现读取的数据值是一样的,但是结果集不一样(对当前读的没改变,但是出现另一个代码)
如何解决
数据库使用”串行化”这样的方式来解决幻读,彻底放弃并发处理事务,一个接一个的串行处理事务
这样做,并发程度是最低的(效率是最慢的),但隔离性是最高的(准确性也是最高的)
数据库内部采取的机制:
read uncommitted 无任何限制
read committed 给写加锁
repeatable read 给写和读加锁
serializable 串行化
上述都是数据库内部机制,可以通过修改MySQL的配置文件,来设置当前MySQL工作在哪种状态下
接下来就是最后的JDBC后,多谢各位读者大佬观看
相关文章:

数据库之约束、索引和事务
一、约束 约束,顾名思义就是数据库对数据库中的数据所给出的一组检验规则.负责判断元素是否符合数据库要求.其目的就是为了提高效率以及准确性. 1.not null - > 数据元素非空 表示如果插入数据,则当前数据不能为空. //创建一张学生表,其班级id和年级id不为空 create …...
centos --libreoffice使用
您可以按照以下步骤在CentOS上安装LibreOffice: 打开终端并使用root用户登录。 运行以下命令更新系统软件包: yum update安装LibreOffice依赖项: yum install -y libreoffice-headless libreoffice-writer libreoffice-calc libreoffice-…...

Steam-V Rising 私人服务器架设教程
一、安装前的准备 一台服务器 拥有公网IP并且做好了端口映射 二、使用SteamCMD安装服务器 1.下载SteamCMD SteamCMD是Steam专用的命令行式客户端程序,所有的安装方式可以参照:https://developer.valvesoftware.com/wiki/SteamCMD 或者在其他站点自行…...

SpringBoot+Vue3实现登录验证码功能
系列文章目录 Redis缓存穿透、击穿、雪崩问题及解决方法Spring Cache的使用–快速上手篇分页查询–Java项目实战篇全局异常处理–Java实战项目篇 Java实现发送邮件(定时自动发送邮件)_java邮件通知_心态还需努力呀的博客-CSDN博客 该系列文章持续更新…...

spring2:创建和使用
目录 1.创建Spring项目 1.1创建Maven类 1.2添加Spring支持框架 1.3添加启动类 2.存储Bean对象 2.0 spring项目中添加配置文件(第一次) 2.1创建Bean 2.2把Bean注册到容器中 3.获取并使用Bean对象 3.1创建上下文 3.2获取指定Bean对象 getBean()方法 --> 获取什么…...
前端如何处理后端一次性传来的10w条数据?
写在前面 如果你在面试中被问到这个问题,你可以用下面的内容回答这个问题,如果你在工作中遇到这个问题,你应该先揍那个写 API 的人。 创建服务器 为了方便后续测试,我们可以使用node创建一个简单的服务器。 const http requir…...

Codeforces Round 867 (Div. 3)(A-G2)
文章目录 A. TubeTube Feed1、题目2、分析3、代码, B. Karina and Array1、题目2、分析3、代码 C. Bun Lover1、问题2、分析(1)观察样例法(2)正解推导 3、代码 D. Super-Permutation1、问题2、分析(1&#…...

蓝奥声核心技术分享——一种无线低功耗配置技术
1.技术背景 无线低功耗配置技术指基于对目标场景状态变化的协同感知而获得触发响应并进行智能决策,属于蓝奥声核心技术--边缘协同感知(EICS)技术的关键支撑性技术之一。该项技术涉及物联网边缘域的无线通信技术领域,具体主要涉及网络服务节点…...

kafka集群模拟单节点故障
这里通过kafka manage来展示节点宕机效果 现在三台主机节点均正常 topic正常识别到三个broker leader也均匀分配到了三个broker上 现在把节点id为0的主机模拟宕机 可以通过以上两张图片看到每个topic现在只识别到了两个broker节点,broker id为0的节点已经被剔除掉了 isr列…...
笔记:vue-cli-service
vue-cli-service serve 这个是什么意思? vue-cli-service serve 是一个 Vue.js CLI 命令,用于在本地开发环境下运行一个开发服务器,以便你可以在浏览器中查看和测试你的 Vue.js 应用程序。它在开发期间提供了自动重载、热模块替换和其它实用…...

Amazon S3 对象存储Java API操作记录(Minio与S3 SDK两种实现)
缘起 今年(2023年) 2月的时候做了个适配Amazon S3对象存储接口的需求,由于4月份自学考试临近,一直在备考就拖着没总结记录下,开发联调过程中也出现过一些奇葩的问题,最近人刚从考试缓过来顺手记录一下。 S3对象存储的基本概念 …...
ChatGPT技术原理 第六章:对话生成技术
目录 6.1 任务定义 6.2 基于检索的方法 6.3 基于生成的方法 6.4 评价指标 6.1 任务定义 对话生成技术是指使用自然语言处理技术生成与人类语言相似的对话。在对话生成任务中,模型需要理解输入的语境、用户的意图和上下文信息,然后生成能够回答用户问题…...

【C++ 八】写文件、读文件
写文件、读文件 文章目录 写文件、读文件前言1 文本文件1.1 写文件1.2 读文件 2 二进制文件2.1 写文件2.2 读文件 前言 本文包含文本文件写文件、文本文件读文件、二进制写文件、二进制读文件。 程序运行时产生的数据都属于临时数据,程序一旦运行结束都会被释放 通…...
【学习笔记】CF613E Puzzle Lover
这题本质上还是数据结构。 首先看到这个 2 n 2\times n 2n的网格图就很容易想到分治。我们还是考虑把要统计的东西变得可视化,一条路径要么穿过中线一次,那么我们可以将两边的串拼起来得到答案;要么穿过中线两次,考虑其中一边的…...
软考报名资格审核要多久?证明材料要哪些?
软考报名资格审核要多久? 一般来说,软考资格审核时间不超过1个工作日。当然,每个地区的具体情况都不一样。有些地区估计需要1-3个工作日。总之,为了顺利成功报名,大家应尽快报名,不要拖到最后一天。 软考…...
2023-04-27 polardbx-LSM-tree的Parallel Recovery性能优化
背景 数据库的Crash Recovery时长关系到数据库的可用性SLA、故障止损时间、升级效率等多个方面。本文描述了针对X-Engine数据库存储引擎的一种Crash Recovery优化手段,在典型场景下可以显著缩短数据库实例的故障恢复时间,提升用户使用感受。 当前面临的问题 X-Engine是阿里…...

创作纪念日让 AI 与我共同记录下今天 — 【第五周年、1460天】
今天正是五一,收到一条消息? 五一还要我加班 😏? 喔,原来是 CSDN 给我发的消息呀!我在 CSDN 不知不觉已经开启第五周年啦! 目录 1.机缘2.收获3.日常4.我与 AI 的“合作”part Ipart II Super al…...
枚举法计算24点游戏
# 请在此处编写代码 # 24点游戏 import itertools# 计算24点游戏代码 def twentyfour(cards):"""(1)itertools.permutations(可迭代对象):通俗地讲,就是返回可迭代对象的所有数学全排列方式。itertools.permutations("1118") -…...
@Cacheable注解
Cacheable注解是Spring框架中提供的一种缓存技术, 用于标记一个方法的返回值可以被缓存起来,当再次调用该方法时,如果缓存中已经存在缓存的结果,则直接从缓存中获取结果而不是再次执行该方法,从而提高系统的性能和响应…...

CentOS分区挂载 fdisk、parted方式解析
1 介绍 在linux中,通常会将持久化数据保存到硬盘当中,但是硬盘一把会比较大,因此我们为了方便管理,会将一个硬盘分成多个逻辑硬盘,称之为分区。 为了能够让分区中的文件使得能让操作系统处理,则需要对分区…...
web vue 项目 Docker化部署
Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段: 构建阶段(Build Stage):…...
生成xcframework
打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式,可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...

阿里云ACP云计算备考笔记 (5)——弹性伸缩
目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...

以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:
一、属性动画概述NETX 作用:实现组件通用属性的渐变过渡效果,提升用户体验。支持属性:width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项: 布局类属性(如宽高)变化时&#…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...

2.Vue编写一个app
1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...

定时器任务——若依源码分析
分析util包下面的工具类schedule utils: ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类,封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz,先构建任务的 JobD…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...

2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...