云数据库应用(MySQL) 第9章 MySQL编程基础(四).pptVIP

云数据库应用(MySQL) 第9章 MySQL编程基础(四).ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* 7)在SQLyog中查看表xsqk插入后的数据,如图9.24所示。 从图9.24可见,在xsqk表中已插入了一条新的记录。 * 4)再开启一个事务 mysql begin; Query OK, 0 rows affected (0.00 sec) 5)再插入一条记录到xsqk表中 mysql insert into xsqk values(2016110408,王天,男,1997-12-06,云计算,计算机学院,1357452548,null,null) ; Query OK, 1 row affected (0.06 sec) 6)现在查询学号为’2016110408’的学生情况: mysql select * from xsqk where 学号=2016110408; ……. 从查询结果可见,新增学生已加入到表xsqk中了,但这并没有写入磁盘! * 7)在回滚事务后,再查询表xsqk表中的数据,如图9.25所示。 可见,在事务回滚后,最后添加的学生信息并没有添加到表中。 * 数据库是被多客户所共享访问的,所以很容易出现多个线程同时开启事务的情况。这样就很可能出现以下几种不确定情况。 数据丢失:如果在系统没有执行任何的锁操作的情况下,当多个事务都同时更新一行数据时,一个事务对数据的更新会另一个事务对数据的更新覆盖了,从面造成数据丢失。 脏读:一个事务读取到了另一个事务未提交的数据操作结果。 不可重复读(Non-repeatable Reads):一个事务对同一行数据重复读取两次,但是却得到了不同的结果,即产生了虚读,也就是当事务一读取某一数据后,事务二对其做了修改,当事务一再次读该数据时得到与前一次不同的值; 事务隔离级别 Part 4 * ? 幻读(Phantom Reads):指事务在操作过程中进行两次查询,第二次查询的结果包含了第一次查询中未出现的数据或者缺少了第一次查询中出现的数据,这是因为在两次查询过程中有另外一个事务更新了数据造成的。 为了避免上面出现的几种情况,在标准SQL规范中,定义了4个事务隔离级别,不同的隔离级别对事务的处理不同。 * 也称为未授权读取,允许脏读(Dirty Read),但不允许更新丢失。如果一个事务已经开始写数据,则另外一个事务则不允许同时进行写操作,但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。 1读未提交(Read Uncommitted) * 修改事务级别的语法规则: SET [ GLOBAL | SESSION ] TRANSACTION ISOLATION LEVEL Read uncommitted | Read committed | Repeatable read| Serializable; 其中,GLOBAL表示此语句将应用于在此之后的所有session,而当前已经存在的session不受影响;SESSION表示此语句将应用于包括当前session内的之后所有事务;如果缺省,表示此语句将应用于当前session在内的后面还未开始的事务。 Read uncommitted | Read committed | Repeatable read | Serializable分别表示设置为读未提交、读已提交、可重复读和可串行化。 * 例如,将隔离级别设置为read uncommitted(读未提交),并且当前已经存在的session不受影响的SQL语句: mysql SET GLOBAL TRANSACTION ISOLATION LEVEL Read uncommitted; 设置读未提交隔离级别之后,查看当前的隔离级别,如图9.26所示: * 将当前级别改为可重复读(Repeatable),并且当前已经存在的session不受影响的SQL语句: mysql SET GLOBAL TRANSACTION ISOLATION LEVEL Repeatable read; 更改为可重复读隔离级别之后,查看当前的隔离级别,如图9.27所示: 谢谢观看 * * * * * 第9章 MySQL编程基础 (四) * CONTENTS * 事务概述 Part 1 事务隔离级别 Part 4 事务控制 Part 2 * 当多个用户访问同一个数据时,一个用户在对数据进行修改的同时,可能其他用户也发起了对该数据的修改请求,为了保证数据的更新从一个一致性状态转入了另一个一致性状态,在MySQL中引入了事务的机制概念来解决这个问题。 事务是单个的工作单元,是数据库中不可再分的基本部分。

文档评论(0)

笑笑 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档