MySQL嵌套事务所遇到的问题的代码实例详解
技术百科
黄舟
发布时间:2017-03-06
浏览: 次 这篇文章主要介绍了mysql嵌套事务所遇到的问题的相关资料,需要的朋友可以参考下
MySQL是支持嵌套事务的,但是没多少人会这么干的…. 前段时间在国外看到一些老外在争论MySQL嵌套事务的场景必要性。 逗死我了, 这嵌套的鬼畜用法还有啥场景必要性。 跟以前的dba同事聊过, 得知,在任何场景下都不要使用MySQL嵌套的事务。
那么使用MySQL嵌套事务会遇到什么问题 ?
mysql> select * from ceshi; +------+ | n | +------+ | 1 | +------+ 1 row in set (0.00 sec) mysql> start transaction ; Query OK, 0 rows affected (0.00 sec) mysql> insert into ceshi values(2); Query OK, 1 row affected (0.00 sec) mysql> start transaction ; Query OK, 0 rows affected (0.00 sec) mysql> insert into ceshi values(3); Query OK, 1 row affected (0.00 sec) mysql> commit; Query OK, 0 rows affected (0.00 sec) mysql> rollback; Query OK, 0 rows affected (0.00 sec)
虽然我在最后rollback回滚了,但是数据显示是 1 2 3 . 原本大家以为我的事务虽然是嵌套的状态,但感觉最后rollback回滚了,其实我们希望看到的结果是 子事务执行成功,外层事务的失败会回滚的。 但事实不是这样的,最后的结果是 1 2 3 .
+-----+ | n | +-----+ | 1 | | 2 | | 3 | +-----+
当sql解释器遇到 start transaction 时候会触发commit… !!!
begin_1 sql_1 begin_2 sql_2 sql_3 commit_1 rollback_1 .
begin_2 被执行的时候, sql_1 已经就被提交了, 当你再去执行commit_1的时候,那么sql_2 和 sql_3 就被提交了. 这时候你再去rollback,一定用都没有…. 因为先前都提交完了,你能回滚啥…
前面说过 在架构上一般很少很少有人会 嵌套使用事务,但有时候不小心被嵌套了。 我们拿python的项目来说,首先我们使用装饰器来实现事务的包装, 接着数据处理 def a() 和 def b() 函数都被事务被包装起来, 单纯的用a 和 b 都没关系,都是单事务。 如果 a 逻辑里又调用 b, 那么会发生什么? 对的,事务嵌套了… 我想这是绝大数业务开发都会遇到的问题。
那么怎么规避这风险 ? 可以加锁呀…. 设立一个全局锁,当子事务创建前会判断锁的状态….
如果你是flask的框架,可以使用 flask g 全局变量。
如果是django框架, 那么可以使用 thread local使用全局变量。
如果是tornado、gevent这种异步io架构,可以使用 fd 做协程变量的关联。
@decorator
def with_transaction(f, *args, **kwargs):
db = connection.get_db_by_table("*")
try:
db.begin()
ret = f(*args, **kwargs)
db.commit()
except:
db.rollback()
raise
return ret
@with_transaction
def hide(self):
'''订单不在app端显示'''
if self.status not in OrderStatus.allow_deletion_statuses():
raise OrderStatusChangeNotAllowed(self.status, OrderStatus.deleted)
...
@with_transaction
def change_receipt_info(self, address, name, phone):
region = Region.get_by_address(address)
...
当我们去执行下面语句的时候,事务会被强制提交. 当然这里前提是 autocommit = True 。
ALTER FUNCTION ALTER PROCEDURE ALTER TABLEBEGIN CREATE DATABASE CREATE FUNCTION CREATE INDEX CREATE PROCEDURE CREATE TABLE DROP DATABASE DROP FUNCTION DROP INDEX DROP PROCEDURE DROP TABLE UNLOCK TABLES LOAD MASTER DATA LOCK TABLES RENAME TABLE TRUNCATE TABLE SET AUTOCOMMIT=1 START TRANSACTION
以上就是MySQL嵌套事务所遇到的问题的代码实例详解的内容,更多相关内容请关注PHP中文网(www.)!
# 我在
# 都是
# 这是
# 我想
# 相关内容
# 人会
# 你是
# 可以使用
# mysql
# 全局变量
# 再去
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- c++中explicit(bool)的用法 c++
- 电脑无法识别U盘怎么办 Windows磁盘管理与驱
- 如何在 Go 中正确初始化结构体中的 map 字段
- Win10怎么查看内存时序参数_Win10CPU-
- Windows10如何更改系统字体大小_Win10
- Win11如何设置文件权限 Win11 NTFS文
- Mac如何修改Hosts文件?(本地开发与屏蔽网站
- C++如何编写函数模板?(泛型编程入门)
- php做exe支持多线程吗_并发处理实现方式【详解
- Linux怎么实现内网穿透_Linux安装Frp客
- php中常量能用::访问吗_类常量与作用域操作符使
- Win11此电脑不在桌面上_Windows 11桌
- PyTorch DDP 多进程训练在 Kaggle
- Win11怎么关闭资讯和兴趣_Windows11任
- Win11怎么查看显卡显存_查询Win11显卡详细
- c++ stringstream用法详解_c++字
- Win11怎么设置指纹解锁 Win11笔记本录入指
- C++友元类使用场景_C++类间协作设计方式讲解
- Win11如何设置开机问候语 Win11修改登录界
- Win10怎样卸载DockerDesktop_Wi
- 如何在Golang中处理云原生事件_使用Event
- 如何在Golang中处理通道发送接收错误_防止阻塞
- C#如何在一个XML文件中查找并替换文本内容
- php删除数据怎么清空表_truncate与del
- MAC如何快速搜索大文件_MAC磁盘空间分析与冗余
- Win10怎么创建桌面快捷方式 Win10为应用创
- c# F# 的 MailboxProcessor
- 如何减少Golang内存碎片化_Golang内存分
- Windows11怎么自定义任务栏_Windows
- 如何解决同一段404代码在不同主机上表现不一致的问
- windows系统如何安装cab更新补丁_wind
- Go语言中CookieJar的持久化机制解析:内存
- mac怎么分屏_MAC双屏显示与分屏操作技巧【指南
- c++中如何使用auto关键字_c++11类型推导
- 如何使用Golang安装API文档生成工具_快速生
- 如何在Golang中实现微服务负载均衡_Golan
- 如何在 Laravel 中通过嵌套关联关系进行 o
- 如何在Golang中编写端到端测试_Golang
- Win11怎么关闭粘滞键_彻底禁用Windows
- 如何使用Golang实现聊天室消息存档_存储聊天记
- Win11怎么调整屏幕亮度_Windows 11调
- Windows10如何更改鼠标灵敏度_Win10鼠
- Win10怎样安装Excel数据分析工具_Win1
- 如何使用Golang实现Web表单数据绑定_自动映
- 如何在 Go 中正确测试带 Cookie 的 HT
- Windows 11无法安全删除U盘提示设备正在使
- c++中如何使用虚函数实现多态_c++多态性实现原
- Windows服务启动类型恢复方法_错误修改导致的
- c++如何获取map中所有的键_C++遍历键值对提
- Win11怎么关闭自动维护 Win11禁用系统自动

BEGIN
CREATE DATABASE
CREATE FUNCTION
CREATE INDEX
CREATE PROCEDURE
CREATE TABLE
DROP DATABASE
DROP FUNCTION
DROP INDEX
DROP PROCEDURE
DROP TABLE
UNLOCK TABLES
LOAD MASTER DATA
LOCK TABLES
RENAME TABLE
TRUNCATE TABLE
SET AUTOCOMMIT=1
START TRANSACTION
QQ客服