精通Hibernate:Java持久化对象技术详解[第二版](光盘附带内容)7.pptVIP

精通Hibernate:Java持久化对象技术详解[第二版](光盘附带内容)7.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文档。上传文档
查看更多
精通Hibernate:Java持久化对象技术详解[第二版](光盘附带内容)7

数据库事务与并发 教学内容 数据库事务的概念 声明事务边界 并发问题 设置事务隔离级别 使用悲观锁解决并发问题 使用乐观锁解决并发问题 数据库事务的概念 事务是指一组相互依赖的操作行为,如银行交易、股票交易或网上购物。事务的成功取决于这些相互依赖的操作行为是否都能执行成功,只要有一个操作行为失败,就意味着整个事务失败。例如,Tom到银行办理转账事务,把100元钱转到Jack的账号上,这个事务包含以下操作行为: (1)从Tom的账户上减去100元。 (2)往Jack的账户上增加100元。 显然,以上两个操作必须作为一个不可分割的工作单元。假如仅仅第一步操作执行成功,使得Tom的账户上扣除了100元,但是第二步操作执行失败,Jack的账户上没有增加100元,那么整个事务失败。 数据库事务是对现实生活中事务的模拟,它由一组在业务逻辑上相互依赖的SQL语句组成。 数据库事务的生命周期 MySQL数据库系统的客户程序 声明事务的边界 事务的开始边界。 事务的正常结束边界(COMMIT):提交事务,永久保存被事务更新后的数据库状态。 事务的异常结束边界(ROLLBACK):撤销事务,使数据库退回到执行事务前的初始状态。 在mysql.exe程序中声明事务 每启动一个mysql.exe程序,就会得到一个单独的数据库连接。每个数据库连接都有个全局变量@@autocommit,表示当前的事务模式,它有两个可选值: 0:表示手工提交模式。 1:默认值,表示自动提交模式。 如果要察看当前的事务模式,可使用如下SQL命令: mysql select @@autocommit 如果要把当前的事务模式改为手工提交模式,可使用如下SQL命令: mysql set autocommit=0; 在MySQL中创建支持事务的表 在MySQL中,数据库表分为三种类型:INNODB、BDB和MyISAM类型。其中InnoDB和BDB类型的表支持数据库事务,而MyISAM类型的表不支持事务。在MySQL中用create table语句新建的表默认为MyISAM类型。如果希望创建INNODB类型的表,可以采用以下形式的DDL语句: create table ACCOUNTS ( ID bigint not null, NAME varchar(15), BALANCE decimal(10,2), primary key (ID) ) type=INNODB; 在自动提交模式下运行事务 在自动提交模式下,每个SQL语句都是一个独立的事务。如果在一个mysql.exe程序中执行SQL语句: mysqlinsert into ACCOUNTS values(1,Tom,1000); MySQL会自动提交这个事务,这意味着向ACCOUNTS表中新插入的记录会永久保存在数据库中。此时在另一个mysql.exe程序中执行SQL语句: mysqlselect * from ACCOUNTS; 这条select语句会查询到ID为1的ACCOUNTS记录。这表明在第一个mysql.exe程序中插入的ACCOUNTS记录被永久保存,这体现了事务的ACID特性中的永久性。 在手工提交模式下运行事务 在手工提交模式下,必须显式指定事务开始边界和结束边界: 事务的开始边界:begin 提交事务:commit 撤销事务:rollback 在手工提交模式下运行事务 (1)启动两个mysql.exe程序,在两个程序中都执行以下命令,以便设定手工提交事务模式: mysqlset autocommit=0; (2)在第一个mysql.exe程序中执行SQL语句: mysqlbegin; mysqlinsert into ACCOUNTS values(2, Jack,1000); (3)在第二个mysql.exe程序中执行SQL语句: mysqlbegin; mysqlselect * from ACCOUNTS; mysqlcommit; 以上select语句的查询结果中并不包含ID为2的ACCOUNTS记录,这是因为第一个mysql.exe程序还没有提交事务。 (4)在第一个mysql.exe程序中执行以下SQL语句,以便提交事务: mysqlcommit; (5)在第二个mysql.exe程序中执行SQL语句: mysqlbegin; mysqlselect * from ACCOUNTS; mysqlcommit; 此时,select语句的查询结果中会包含ID为2的ACCOUNTS记录,这是因为第一个mysql.exe程序已经提交事务。 通过JDBC API声明事务边界 Connection类提供了以下用于控制事务的方法: setAutoCom

文档评论(0)

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

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

1亿VIP精品文档

相关文档