IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL三范式与事务、索引详解 -> 正文阅读

[大数据]MySQL三范式与事务、索引详解

?

目录

了解事务和索引

一、数据库三范式

1.表中的每个字段从业务上不可再分

2.表中的字段完全依赖于主键

3.表中的任何非主键字段不依赖其他非主键字段

二、事务(Transactio)

1.一致性(Consistency)

2.持久性(Durability)

3.原子性(Atomic)

4.隔离性(Isolation)

1.读未提交

2.读已提交

?3.可重复读

4.可串行性

三、如何去使用事务

1.直接使用sql

1.commit

2.rollbackll

2.通过JDBC

四、索引

1.索引如何的快速查询

2.索引的适用范围

总结


了解事务和索引

首先了解什么是事务:一个事务就是为了执行一个业务的一个或者多个语句。例如我们耳熟能详的图书馆管理系统,其中的借书的这一个功能,简略的来说最起码设计两个sql语句;一个是对于书的数量减少(update),二是在借书记录的表里面加入(insert)一条谁借了什么数。所以这两个sql就要作为一个整体,并且具有不可分割的特性。

关于索引,这里我只是简述了普通的索引的功能。


一、数据库三范式

1.表中的每个字段从业务上不可再分

确保表里的每一列都保证原子性,为了方便与统计与查询

2.表中的字段完全依赖于主键

就是表中的非主键不存在最对主键的部分的依赖(就是有一部分非主键可能表述的是另一个事件,与这个表里面描述的事情没有关系);他的作用为了保证每一行数据都可以通过主键划分。

3.表中的任何非主键字段不依赖其他非主键字段

作用是为了减少表的数据存储,让相互依赖的非主键字段单独的组成一个关系表即可。

二、事务(Transactio)

首先前面简单的说了对于事务的一个认识,下面就来描述一下为了做到支持事务的功能DBMS(数据库管理系统)满足的4个特性(ACID)。

1.一致性(Consistency)

首先要清楚什么是一致性,这里我先举一个例子;还是图书馆管理系统例如,图书馆里面某一本(一样的好几本书)书的借出量一定小于等于它原先的总量。可以看出这就是一个维护数据一致性的例子,也就是数据的一致性不光是DBMS替我们保证的,也要我们开发者公共的参与进来。

下面显示特性间的关系:

2.持久性(Durability)

这个很好的理解,就是一旦DBMS通知我们数据修改成功了,则数据一定被修改成功了。

3.原子性(Atomic)

原子性,就是业务动作对应的sql应该看作一个整体,是不可以在分开的。例如对于图书馆管理系统里面的借书,就必须要对应一个借书记录的sql和书量信息的sql他们两个的执行应该是不可以分割的。

4.隔离性(Isolation)

隔离性就是多个DBMS用户同时(宏观下的)对同一批数据进行增删改查时,相互之间需要保持隔离的特性。但是追求隔离性和并发性之间是相互矛盾的,也就是如果追求隔离性,他的数据会正确性越高,但是运行的速度会降低,并发性差;追求并发性越好时,他的隔离性必然会较差,也就是数据的正确行会降低。所以规定了隔离级别(isolation level)

隔离级别的划分:

?其中的快照读不是标准中存在的隔离级别。

1.读未提交

对这个最直观的解释就是:多个同时(宏观)在执行的事务,可以读取到其他的事务还处于未提交时 的数据的修改。这个最大的副作用就是会产生脏读。

直观的图形展示:

2.读已提交

就是可以看到别的事务已经提交的数据,但也会有副作用那就是不可重复读

话不多说,直接上图:

?3.可重复读

保证在一次事务中看到的数据是不会发生变化的(即使有别的事务对数据进行了修改并且已经提交)。这种方式会产生幻读。

继续上图:

那么什么是幻读那:就是出现了像幽灵一样的数据,无端的出现~~~

下面的这个图更好的理解幻读:

?前面提到的"快照读"就可以看作在可重复读的基础上消除了幻读的副作用。

4.可串行性

其实就是每个事务,都得排队执行,一次一个事务。所以不会产生上述的种种的副作用。但是也有很大的缺点,那就是并发行差,执行的速度慢。

三、如何去使用事务

1.直接使用sql

这里直接的通过workbench去使用事务

--将下面的看作是一个事务的整体去执行

start transaction? ?

?sql1

?sql2

?sql3

rollback/commit? ?

1.commit

如果代码成功执行表示全部成功。

如果被动失败(硬件故障、软件的问题) ,由于没有执行commit,事务期间的部分修改会被回滚。

2.rollbackll

主动的要求回滚。

2.通过JDBC

首先JDBC就是Java专门针对数据库而制定的一个标准(所以都为抽象类、接口),而真正的实现类则是我们下载的第三发库(例如mysql官方)。

然后就是我们在使用在Java环境下对于数据库的操作,这里简单的说下就是一次事务就相当于建立一个连接,对数据库进行操作。

?

四、索引

索引的种类有很多,像主键、唯一键都可以叫做索引。这里我只是简单的讨论了普通索引

首先添加索引的目的:个某些字段加入索引,为了提升对于该字段数据的查询速度。

1.索引如何的快速查询

首先,对于没有加索引的数据,按主键的排序在硬盘中存着按照线性表的方式(一种可能性),我们要找到某个字段需要的时间复杂度O(n);

当我们针对某个字段(假设为name_a)加入索引时,实际就为这个字段添加了一个关于这个他的搜索树(类似保存 (key,value)),当我们搜索这个字段时,就可以通过找到的key(name_a),获取value值,这里的value是对应这个字段在硬盘中的存储位置(一种可能性)。这样的时间的复杂度就为O(logn);

2.索引的适用范围

1.首先是数据量有一定的规模,充分的体现出O(logn)的性能。

2.针对查询多,修改少的(删除、修改、增加都会修改搜索树的结构,性能会下降)。

3.针对频繁查询的字段建立索引。


总结

每天加油一点点~~~

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-08-06 10:50:33  更:2022-08-06 10:53:28 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 0:02:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码