mysql 第十三次作业(事务的管理)

事务的开启
语法:start  transaction;

事务开启之后就可以执行SQL语句,SQL语句执行成功后需要使用相应语句提交事务

SQL语句:

数据定义语句(DDL):主要用于定义数据库,数据表等(create)
数据操纵语句(DML):主要用于对数据库中的数据进行添加,修改和删除操作(alter,insert)

数据查询语句(DQL):主要用于查询数据(select)
数据控制语句(DCL): 主要用于控制用户的访问权限

提交事务
语法:commit;

注:事务中的操作语句都需要使用语句commit手动提交,提交后操作才会生效。

设置保存点(用于在事务内设置保存点)
语法:savepoint 保存点名称;

如不想提交当前事务,可取消事务。

取消事务(也称回滚)
语法:rollback;(只针对未提交的事务,已提交的事务不能执行)

语法:rollback to savepoint 保存点名称;(撤销事务中保存点之后的执行语句)

设置事务隔离级别
语句:set session transaction isolation level 隔离级别;

一、使用事务
接下来通过转账案例来演示如何使用事务。

1.首先创建数据库:

2.在库中创建表:

3.在表中插入数据:

4.验证是否插入成功,用select语句查询:

接下来使用事务演示如何实现转账功能。

1.首先开启事务:

2..通过update语句将a账户的100元钱转入b账户 ,提交事务:

 

3.使用select语句查询 account表中的余额:

二、提交事务

1.首先开启事务:

2.通过update语句将b账户的100元钱转入a账户  

 3.使用select语句查询 account表中的余额:

 

4.退出数据库并重新登录,再使用select语句查询 account表中的余额:

5.可以看出转账操作没有成功,这是因为事务中的语句不能自动提交。

接下来使用commit语句提交事务:

6.使用select语句查询 account表中的余额:

 

三、事务的回滚

1.开启事务,通过update语句将a账户的100元钱转入b账户 :

2.使用select语句查询 account表中的余额:

 

由于事务没有提交,就可以将事务撤销,也称回滚。

如图所示:

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js中使用MySQL服务时,可以通过事务管理来执行多条SQL操作,以确保原子性和数据一致性。事务是将一组操作视为一个单独的单元来执行,要么全部成功,要么全部失败。在Node.js中,可以使用Promise来封装事务操作。 首先,需要导入MySQL的连接池对象,例如使用`const pool = require("../db/mysql")`导入pool对象。然后,可以封装一个执行事务的函数`execTransaction`,该函数接受一个包含多个SQL语句的数组作为参数。 在`execTransaction`函数中,首先通过连接池获取一个数据库连接,然后开始事务。接下来,将所有需要执行的SQL语句封装为Promise数组,每个Promise代表一个SQL执行操作。在Promise中,使用连接对象的`query`方法执行SQL语句,并将结果返回。 使用`Promise.all`来等待所有的SQL操作完成,如果其中有任何一个操作出错,将回滚事务,并且释放连接。如果所有操作都成功执行,将提交事务,并释放连接。最后,通过`resolve`将结果返回。 这样,通过封装的`execTransaction`函数,可以在Node.js中方便地执行MySQL事务管理操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Nodejs实现Mysql事务的解决方案](https://blog.csdn.net/weixin_41464806/article/details/106446449)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [NodeJs使用Mysql模块实现事务处理实例](https://download.csdn.net/download/weixin_38678796/14858646)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值