数据库之约束、索引和事务

news2024/11/16 10:20:20

一、约束

约束,顾名思义就是数据库对数据库中的数据所给出的一组检验规则.负责判断元素是否符合数据库要求.其目的就是为了提高效率以及准确性.

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后,多谢各位读者大佬观看

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

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

相关文章

深度学习 - 42.特征交叉与 SENET、Bilinear Interaction 与 FiBiNet

目录 一.引言 二.摘要 - ABSTRACT 三.介绍 - INTRODUCTION 四.相关工作 - RELATED WORK 1.因式分解机及其变体 - Factorization Machine and Its relevant variants 2. 基于深度学习的点击率模型 - Deep Learning based CTR Models 3.SENET Module 五.FiBiNet Model 1…

4核8G云服务器腾讯云CVM S5和轻量应用服务器性能差异?

腾讯云4核8G云服务器可以选择轻量应用服务器或CVM云服务器标准型S5实例,轻量4核8G12M服务器446元一年,CVM S5云服务器935元一年,相对于云服务器CVM,轻量应用服务器性价比更高,轻量服务器CPU和CVM有区别吗?性…

PXE 网络安装Linux ——Kickstart无人值守安装Linux

PXE(预启动执行环境) PXE(预启动执行环境) 由Intel公司开发的网络引导技术,工作在Client/Server模式,允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。 PXE具备以…

【Leetcode -234.回文链表 -160.相交链表】

Leetcode Leetcode -234.回文链表Leetcode -160.相交链表 Leetcode -234.回文链表 题目:给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。 示例 1: 输…

上新了丨高性价比5G智能模组,美格智能SRM700正式发布

伴随着5G、AI、云计算等技术与物联网技术的融合发展,一个万物智联的智能世界正在到来。5G已经成为数字经济重要的基础设施,千行百业的用户都需要依靠高速率、大带宽、低延时的5G技术来构建数字化转型能力。 作为全球领先的无线通信模组及解决方案提供商…

跳槽必备,全面总结Android面试知识点

在最近的 Android 开发(社招)面试中总结的 Android 基础知识点,已经拿到心仪的offer,回馈同学们,感谢其他大佬的分享。 Android中大厂面试都很重视基础知识的考察,面试前不仅要熟悉这些知识点,…

射频封装技术:层压基板和无源器件集成

射频和无线产品领域可以使用非常广泛的封装载体技术,它们包括引线框架、层压基板、低温共烧陶瓷(LTCC)和硅底板载体(Si Backplane)。由于不断增加的功能对集成度有了更高要求,市场对系统级封装方法&#xf…

精进云原生 - Dubbo 3.2 正式发布

作者:Dubbo 社区 我们非常高兴地宣布,Dubbo 3.2 已经正式发布了!这个版本带来了许多新功能和改进,这也是 Dubbo 在面对云原生化的当下的一次重要的尝试。 背景介绍 Apache Dubbo 是一款 RPC 服务开发框架,用于解决微…

nodejs+vue 蛋糕甜品商城系统

根据蛋糕甜品商城系统的功能需求,进行系统设计。 系统功能:用户进入系统可以对首页、商品信息,公告信息,个人中心、购物车,客服中心等功能进行操作; 后台主要是管理员,管理员功能包括个人中心、…

大学生用什么蓝牙耳机好?2023好用的蓝牙耳机推荐

近几年,蓝牙耳机市场不断扩大,逐渐取代有线耳机成为最受人欢迎的数码产品之一。作为蓝牙耳机主要受众群的大学生,用什么蓝牙耳机比较好呢?下面,我来给大家推荐几款便宜好用的蓝牙耳机,一起来看看吧。 一、…

apple pencil必须要买吗?高性价比电容笔排行榜

可能很多人都觉得苹果的原装电容笔是无可替代的,但在我看来,这是要看我们的预算和需要了。如果你对绘画的要求不是很高,你可以选择平替电容笔,而并非Apple Pencil,因为它的价格非常昂贵。为了让大家对电容笔有更深的了…

KeePass搭建一个私人密码库

本文转载于我的博客KeePass搭建一个私人密码库 前言 {% note info no-icon %} 既然有人想看那我就不咕了嘻嘻 {% endnote %} 不知道在哪部电影里看到过这样一句话:根据社会工程学,正常人人脑是不会记住超过3种以上完全不同的复杂密码 所以你只要泄露一个…

智慧水务建设的发展与配电设计

摘要:目前以新技术应用带动水务信息化技术水平的全面提升,是水务发展的必然趋势,全国智慧水务正如火如荼建设中。智慧水务聚焦供水安全保障与水务精细化管理,本文通过各应用场景深入分析智慧水务建设价值,提出智慧水务…

Redis集群(caluster)

Redis集群(caluster) Redis集群是一个提供在多个Redis节点间共享数据的程序集 1. Redis集群的作用: Redis 集群是 Redis 的分布式实现,在设计中按重要性顺序具有以下目标: 高性能和线性可扩展性,多达 1000 个节点。没有代理,使…

Pyqt应用相关之PDF汇总案例说明

相信有不少小伙伴遇到了想要把多份pdf汇总到一起的问题,本期就带来用Pyqt界面制作的关于pdf汇总的教学流程。 def pdf_files_btn_click(self):files QFileDialog.getOpenFileNames(self, os.getcwd(), opentxt, PDF Files(*.pdf))file_list files[0]self.pdf_file…

2023年6月DAMA-CDGP数据治理专家认证请尽快报名啦!

目前6月DAMA-CDGP数据治理认证考试开放报名地区有:北京、上海、广州、深圳、长沙、呼和浩特。 目前南京、济南、西安、杭州等地区还在接近开考人数中,打算参加6月考试的朋友们可以抓紧时间报名啦!!! 5月初,…

(一)服务发现组件 Eureka

1、Eureka 简介 Eureka 是Spring Cloud Netflix 微服务套件中的一部分, 它基于Netflix Eureka 做了二次封装, 主要负责完成微服务架构中的服务治理功能。我们只需通过简单引入依赖和注解配置就能让Spring Boot 构建的微服务应用轻松地与Eureka 服务治理…

两百左右哪款蓝牙耳机好?两百左右高性价比蓝牙耳机推荐

现如今,蓝牙耳机无疑已经成为学生党外出的标配了。比起一些动辄上千的蓝牙耳机,两百左右的似乎更符合学生党的选择。接下来,我来给大家推荐几款两百左右高性价比的蓝牙耳机,一起来看看吧。 一、南卡小音舱Lite2蓝牙耳机 参考价&…

Spring 循环依赖处理之三级缓存设计

一、思考 1、Spring是如何解决循环依赖问题的? 2、为什么要使用三级缓存?二级缓存能否解决问题? 3、提前暴露对象暴露的是什么? 4、主要源码 二、循环依赖 1、介绍 如上图,创建A之前需要先创建B,创建B之前需要先创建A,造成循环依赖。 由于A没创建完成&am…

C++:IO流

CIO流 C系统实现了一个庞大的类库,其中ios为基类,其他类都是直接或间接派生自ios类 注意: 1. cin为缓冲流。键盘输入的数据保存在缓冲区中,当要提取时,是从缓冲区中拿。如果一次输 入过多,会留在那儿慢慢…