- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
事务的使用 假设张三转让李四一辆二手自行车,李四需要向张三支付199元,则执行的SQL语句如下。 ——撤销事务 START TRANSACTION; UPDATE `account` SET `money`=`money`+199 WHERE `name`=张三; UPDATE `account` SET `money`=`money`-199 WHERE `name`=李四; ① 撤销全部事务处理 任务三:事务处理 事务的使用 执行上述SQL语句后,使用SELECT查询account数据表更新后的变化,如图所示。 ——撤销事务 ① 撤销全部事务处理 任务三:事务处理 事务的使用 从查询结果可知,李四的账户余额为负数,显然不符合正常的业务逻辑。此时就需要使用ROLLBACK命令进行全部事务的回滚,撤销刚才对数据表account的更新操作。具体SQL语句如下。 ——撤销事务 ① 撤销全部事务处理 ROLLBACK; 执行完事务回滚后再进行SELECT查询,结果与开始创建事务查询结果相同。 任务三:事务处理 事务的使用 使用SAVEPOINT可以在事务处理使用指定不同的撤销位置,在需要事务撤销时进行回滚。例如,向数据表account中逐条插入3条记录,并利用SAVEPOINT在每次插入数据后设置一个回滚位置,SQL语句如下。 ——撤销事务 ② 撤销事务到指定位置 START TRANSACTION; INSERT INTO `account` VALUES (NULL, 王五, 500); SAVEPOINT test1; INSERT INTO `account` VALUES (NULL, 赵六, 6000); SAVEPOINT test2; INSERT INTO `account` VALUES (NULL, 李七, 70); SAVEPOINT test3; 任务三:事务处理 事务的使用 上述SQL执行后,进行SELECT查询,就会看到account表中已经存在新插入的这3条记录。 假设从“李七”开始的记录有误需要撤销,就可以回滚到test2位置,具体SQL如下。 ——撤销事务 ② 撤销事务到指定位置 ROLLBACK TO SAVEPOINT test2; 执行上述SQL语句后,查询数据表account中的数据,就会看到新插入的记录中只有“王五”和“赵六”。由此可见,事务可以回滚到想要的位置。 任务三:事务处理 事务的使用 需要注意的是,SAVEPOINT指定回滚位置的操作对于已经提交的事务并不适用,且对于定义了相同名称的回滚位置,则后面的定义会覆盖之前的定义。此外,对于不再需要使用的回滚位置标识,可以通过RELEASE SAVEPOINT命令进行删除。例如,删除回滚位置test1,SQL语句如下。 ——撤销事务 ② 撤销事务到指定位置 RELEASE SAVEPOINT test1; 任务三:事务处理 事务的使用 CHAIN和RELEASE子句可以用来分别定义在事务提交或者回滚之后的操作,CHAIN会立即启动一个新事物,并且和刚才的事务具有相同的隔离级别;RELEASE则会断开和客户端的连接。 例如,向数据表account中添加一条数据后,提交事务并开启新事务,具体SQL语句如下。 ——后续操作 START TRANSACTION; INSERT INTO `account` VALUES (NULL, 郑七, 70); COMMIT AND CHAIN; 任务三:事务处理 事务的使用 接着继续执行插入操作,具体SQL语句如下。 ——后续操作 INSERT INTO `account` VALUES (NULL, 谢八, 8); 执行上述SQL语句后,再打开一个MySQL服务器进程进行查询,可以看到account表中新增记录只有“郑七”没有“谢八”。 任务三:事务处理 事务的使用 接下来提交事务处理并断开与客户端的连接,具体SQL语句如下。 ——后续操作 COMMIT RELEASE; 此时,在查看事务处理结果,如图所示。从查询结果可以看出,使用RELEASE在事务提交后,已经断开与客户端的连接。 任务三:事务处理 事务的使用 事务存在的周期是由用户在命令提示符下输入START TRANSACTION或BEGIN指令开始,直到用户输入COMMIT命令结束。为了便于理解,下面以一个简单事务存在的周期流程图为例进行展示。 ——事务存在的周期 任务三:事务处理 添加外键约束 index_col_name
您可能关注的文档
- Photoshop实战应用第2章.pptx
- Photoshop实战应用第3章.pptx
- Photoshop实战应用第4章.pptx
- Photoshop实战应用第5章.pptx
- Photoshop实战应用第6章.pptx
- Photoshop实战应用第7章.pptx
- Photoshop实战应用第8章.pptx
- Photoshop实战应用第9章.pptx
- Photoshop实战应用第10章.pptx
- Photoshop项目实践教程教学模块八.pptx
- PHP+MySQLl网站开发项目式教程项目三 模块四 PDO数据库抽象层.ppt
- PHP+MySQLl网站开发项目式教程项目三 模块五 MVC开发模式.ppt
- PHP+MySQLl网站开发项目式教程项目三 模块一 开发前准备.ppt
- PHP+MySQLl网站开发项目式教程项目一 模块二 PHP程序设计.ppt
- PHP+MySQLl网站开发项目式教程项目一 模块三 项目代码实现.ppt
- PHP+MySQL网站开发技术项目式教程1-1 搭建项目开发环境.ppt
- PHP+MySQL网站开发技术项目式教程1-2诚信管理论坛需求分析.ppt
- PHP+MySQL网站开发技术项目式教程2-1 诚信管理论坛数据库设计.ppt
- PHP+MySQL网站开发技术项目式教程2-2 诚信管理论坛数据库实现-数据表操作.ppt
- PHP+MySQL网站开发技术项目式教程2-2 诚信管理论坛数据库实现-数据库创建.ppt
文档评论(0)