当前位置: 首页 > news >正文

如何能快速搜到新做网站链接爱站网长尾关键词挖掘工具福利片

如何能快速搜到新做网站链接,爱站网长尾关键词挖掘工具福利片,wordpress主体首页空,编程猫下载目录 1、背景2、事务的特性3、事务之间的几种错误【1】脏读【2】不可重复读【3】幻读 4、事务中的隔离级别5、总结 1、背景 事务是存储引擎层面实现的,有的引擎支持事务,有的引擎不支持事务,我们常用的引擎InnoDB就支持事务,本文…

目录

  • 1、背景
  • 2、事务的特性
  • 3、事务之间的几种错误
    • 【1】脏读
    • 【2】不可重复读
    • 【3】幻读
  • 4、事务中的隔离级别
  • 5、总结

1、背景

事务是存储引擎层面实现的,有的引擎支持事务,有的引擎不支持事务,我们常用的引擎InnoDB就支持事务,本文大概讲解一下事务的特性,后续再讲解事务的MVCC(多版本并发控制)如何实现的。

2、事务的特性

事务的特性满足ACID,A(Atomicity):原子性、C(Consistency):一致性、I(Isolation):隔离性、D(Durability):持久性。

1、原子性:一组操作要么全部成功要么全部失败。
2、一致性:数据库从一个有效的状态变为另一个有效的状态。
3、隔离性:事务间的影响程度,四种级别分别为读未提交、读已提交、可重复读、串行化。
4、持久性:事务提交之后就会永久生效,也就是将数据写入磁盘发生异常能恢复。

3、事务之间的几种错误

假设有张表如下:

CREATE TABLE student
(id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(255) NOT NULL DEFAULT '' COMMENT '姓名'
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;

向其中插入一条数据,后面讲的几种错误都以这条记录作为初始条件:

mysql [xxx]> INSERT INTO student (name) VALUES ('张三');
Query OK, 1 row affected (0.001 sec)mysql [xxx]> SELECT * from student;
+----+--------+
| id | name   |
+----+--------+
|  1 | 张三   |
+----+--------+
1 row in set (0.000 sec)

【1】脏读

事务A读取到了事务B未提交修改之后的数据,事务B发生了回滚,此时事务A读取到的数据就是"脏数据",这就叫脏读,举个例子理解:

时间顺序事务A事务B
t1开始事务开始事务
t2UPDATE student SET name = ‘李四’ WHERE id = 1;
[将"张三"更新为"李四"]
t3SELECT name FROM student WHRER id =1;
[此时读取到的name为"李四"]
t4提交事务
t5回滚事务
[此时name的值变为"张三"]

数据库中原本的name值为"张三",t2时刻事务B将name更新为"李四",t3时刻事务A读取到name为"李四",t4时刻事务A提交,t5时刻事务B发送回滚,此时name的值变为"张三",但是事务A读取到的name还是为"李四",这就是读到了一个无效的数据,叫做"脏读"。

【2】不可重复读

事务A只能读取已提交事务的结果,多个已提交事务结果的不同,事务A就可能读到不同的结果,这就叫不可重复读,示例如下:

时间顺序事务A事务B事务C
t1开始事务开始事务开始事务
t2SELECT name FROM student WHERE id = 1;
[此时读取到的name为"张三"]
t3UPDATE student SET name = ‘李四’ WHERE id =1;
[将"张三"更新为"李四"]
t4提交事务
[此时name为"李四"]
t5SELECT name FROM student WHERE id = 1;
[此时读取到的name为"李四"]
t6UPDATE student SET name= ‘王五’ WHERE id =1;
[将"李四"更新为"王五"]
t7提交事务
[此时name为"王五"]
t8SELECT name FROM student WHERE id = 1;
[此时读取到的name为"王五"]
t9提交事务

上面t2、t5、t8时刻事务A读取的name分别为:“张三”、“李四”、“王五”。一个事务三次读取结果都不一样,这就叫"不可重复读"。

【3】幻读

事务A两次根据某个条件查询两次的结果由于中途事务B进行了插入导致两次查询结果不一致,这就叫幻读。示例如下:

时间顺序事务A事务B
t1开始事务开始事务
t2SELECT name FROM student WHERE id < 10;
[查出来的只有"张三"]
t3INSERT INTO student (name) VALUES (‘李四’);
[新插入一条name为"李四"的记录]
t4提交事务
[此时表中有name为"张三"、"李四"两条记录]
t5SELECT name FROM student WHERE id < 10;
[查出来的有"张三"、“李四”]
t6提交事务

事务A种t2时刻和t3时刻查询条件相同,但t3时刻多出来一条记录,这就叫做"幻读"。

4、事务中的隔离级别

事务中有4种隔离级别

READ UNCOMMITTED未提交读
READ COMMITTED已提交读
REPEATABLE READ可重复读
SERIALIZABLE可串行化

查看mysql中设置的隔离级别如下:

mysql [xxx]> SELECT @@tx_isolation;
+----------------+
| @@tx_isolation |
+----------------+
| READ-COMMITTED |
+----------------+
1 row in set (0.016 sec)

每个隔离级别对应事务之间的问题如下:

脏读不可重复读幻读
未提交读yesyesyes
已提交读noyesyes
可重复读nonoyes
可串行化nonono

未提交读每次都会读取最新的结果;已提交读每次读取的都是已提交事务的结果;可重复读会对所读的行进行加锁,保证读取行的时候不会被其它事务修改;虽然可串行化事务之间不会有并发问题,但是执行效率也是最低的,因为要给每一行去加锁。

5、总结

本文对事务的特性和事务之间的问题有了个大概的认知,后面会再细节讲解事务的回滚机制和MVCC实现原理。

http://www.15wanjia.com/news/45322.html

相关文章:

  • PHP 网站搜索怎么做百度手机端推广
  • wdcp网站迁移世界500强企业排名
  • asp.net网站安装教程广州最新重大新闻
  • 绵阳网站建设100jv小程序商城
  • 免费wap自助建站网站2022年seo最新优化策略
  • 公司网站怎么做教程软文营销的本质
  • 昆明网站建设 技术支持百度一下搜索引擎大全
  • 直播类网站开发互联网广告公司
  • 景观建筑人才网青岛seo青岛黑八网络最强
  • wordpress 下载服务器企业seo顾问公司
  • 如何攻击织梦做的网站方法免费加客源软件
  • wordpress 主菜单 背景重庆公司seo
  • 网站建设禁止谷歌收录的办法自己创建个人免费网站
  • 网页制作与网站管理搜狗推广登录入口
  • 做网站要用什么编程语言发稿推广
  • 济南国画网站建设宁波最好的seo外包
  • 做网站建设需要做哪些工作视频号链接怎么获取
  • 如何学做网站东莞网络优化调查公司
  • wordpress留言板隐藏关键词优化排名软件s
  • 网站内容做淘宝店铺链接影响排名吗百度信息流投放技巧
  • 创意设计网站seo关键词排名优化案例
  • 电子商务网站开发技术有哪些站长工具 忘忧草
  • 网站怎么做必须交钱吗抖音搜索引擎推广
  • 太原网站建设的公司排名可以发外链的平台
  • 青浦手机网站制作网络营销中的四种方法
  • 南宁网站开发公司长沙做网站推广
  • 做网站百度推广广东seo教程
  • 电商自建站南昌seo搜索优化
  • 网站长域名品牌策划
  • 专业做网站全包2023年7月最新疫情