mysql事务的注意

mysql默认自动提交,开启一个事务的时候也就是

set autocommit = 0;

关闭了自动提交,

我们有时候会在执行一个操作的时候,显式的进行锁表操作

比如显式的 写锁表:

lock table aaa write ;

这个时候 需要进行一个inset操作了,如果当前线执行了一个 select 或者其他的行为,好了,你就等着吧,

所以给了一个写锁,你就要执行 写的操作

比如:

insert aaa (aa)values('tset');

如果你没有unlock的时候,这个表一直处于所得状态,其他线程的任何操作是也是一直处于等待的状态,但是此时你在锁表的这个线程 insert以后并没有执行 unlock ,而是开启了一个事务,那么也是造成了一个隐式的unlock table aaa一个效果,

此外注意 事务对一些操作是不能回滚的,比如DDL操作,而且有一部分DDL操作是隐式提交的

当你看到了这篇博客,希望您能使用适合事务的场景中去使用它,而不是为了练习事务,或者处于别的原因而不是项目的某个场景很适合事务而去使用它,

另外在PDO当中, 为了以防万一,使用事务的时候一定要用try catch包裹起来,我们并不能保证程序一定会按照我们想要的去执行,墨菲定律的情况下,没有什么事情是绝对的,

同事给我说,异常也能终止不执行commit ,是的,说的没错,因为PDO帮你处理了,在进程异常的时候PDO会自动帮你rollback回去了, 换成别数据库操作对象类呢??? 一点也不想想, 现在就一个心态,虽然我做了五六年开发,不如一个刚入行的大牛 ,一堆的牢骚,天天看到屎山代码就烦得不得了,高度耦合,不明白类的作用,你能不能保证一个类只干一个事情啊,动不动就有问题,我也是无语了,2023年我说过重复性最多的一句话:你测了吗???为啥说这句话,不明白吗? 心态快给我整没了,

今天更扯,有个问题,他在他机器上测试没事,然后我拉到我本地有问题,,然后他说他的没问题就不管我了,我找了一大圈,在本次后端代码更新中,发现每个ORM 连接信息都被定义到他远程的数据库上,可能是我太笨了吧, 跟他说了一下,他才想起来吧,唉。

写这个博客没别的意思,就是发泄一下心中的不满,时刻告诉我自己,我现在在做一个前端的工作,后端怎么写,关我屁事,我只要我的数据,其他的一概不管,

睡觉

相关推荐
万象.2 小时前
redis数据结构set和zset的基本指令
数据结构·数据库·redis
全栈测试笔记8 小时前
异步函数与异步生成器
linux·服务器·前端·数据库·python
Lee_SmallNorth8 小时前
变态需求之【角色不同访问数据库的用户不同】
java·开发语言·数据库
李慕婉学姐8 小时前
Springboot连锁火锅管理及预测系统sh5s1gn1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
dishugj8 小时前
【oracle】19c集群巡检问题
数据库·oracle
知识分享小能手8 小时前
Oracle 19c入门学习教程,从入门到精通,Oracle 其他数据对象 —— 语法详解与综合实践(11)
数据库·学习·oracle
木风小助理8 小时前
JavaStreamAPI的性能审视,优雅语法背后的隐形成本与优化实践
java·前端·数据库
Knight_AL9 小时前
MySQL InnoDB 锁机制深度解析:行锁、表锁、间隙锁、临键锁(Next-Key Lock)
数据库·mysql
良策金宝AI9 小时前
工程设计企业AI试用落地路径:从效率验证到知识沉淀
数据库·人工智能·知识图谱·ai助手·工程设计
panzer_maus10 小时前
Redis的简单介绍(2)-处理过期Key的策略
数据库·redis·缓存