文档章节

mysql关闭autocommit带来的坑

messud4312
 messud4312
发布于 2015/05/21 18:01
字数 245
阅读 3400
收藏 0

我们打开两个mysql client,首先关闭autocommit。然后分别同时按照从上到下执行,每条语句后面都标上了执行顺序。

mysql> set autocommit = 0;  #1         │mysql> set autocommit = 0;  #2
Query OK, 0 rows affected (0.00 sec)   │Query OK, 0 rows affected (0.00 sec)
                                       │
mysql> insert into user values ("Stupid│mysql> select * from user;  #4
 ET");   #3                            │Empty set (0.00 sec)
Query OK, 1 row affected (0.03 sec)    │
                                       │mysql>
mysql> commit; #5                      │mysql>
Query OK, 0 rows affected (0.02 sec)   │mysql>
                                       │mysql>
mysql> select * from user where name = │mysql> select * from user where name =
"Stupid ET";  #6                       │ "Stupid ET";  #7
+-----------+                          │Empty set (0.00 sec)
| name      |                          │
+-----------+                          │mysql>
| Stupid ET |                          │
+-----------+                          │
1 row in set (0.00 sec)                │

可以看到右边的client里面是查不到新加入的name为”Stupid ET”的用户。

因为在执行#4这条命令的时候,导致右边的client自动进入了一个事务了,而此时数据库是没有的name为”Stupid ET”这个用户的。所以就导致即使数据库里面存在name为”Stupid ET”的记录,右边的client也查不到。


© 著作权归作者所有

共有 人打赏支持
上一篇: mysql innodb锁机制
下一篇: mysql事务 锁
messud4312
粉丝 6
博文 127
码字总数 102329
作品 0
海淀
后端工程师
私信 提问
mysql之innodb引擎使用方法

前言 闲来无事做不如MySQL。 一.简介: 1.Linux下使用MySQL数据库时,为了支持事务操作需要用到InnoDB引擎,对于表中处理的插入,更新等操作失败时 ,回滚前面不应该完成的操作是必须的. 2.一般M...

李伟铭k
07/09
0
0
基于binlog的mysql数据恢复

使用了python-mysql-replication 这个库做mysql数据库的恢复.插桩测试中准备数据.由于是多系统交互,业务较为复杂,所以模拟操作,然后抽取数据流动变化,记录下来.下次直接操作数据库,达到快速新...

豆泥碗
2014/02/21
0
0
mysql start transaction 和 set autocommit = 0 的区别

1、set autocommit = 0 关闭当前会话中事务的自动提交,需要手动 commit 或者 rollback,相当于开启一个全局的事务。在 mysql 的事务中,默认 autocommit = 1,每一次 sql 操作都被认为是一个...

big_cat
2016/11/10
304
0
MySQL事务autocommit自动提交设置

MySQL提交模式 MySQL默认操作模式是 autocommit 自动提交模式。此模式下,除非显式的声明使用事务,即: 开始一个事务,否则每个操作都将被当做一个单独的事务自动提交。 MySQL提交模式查询与...

前世疯狂
03/23
0
0
【整理】MySQL 之 autocommit

mysql 默认是开启 auto commit 的。可以通过如下命令查看 session 级别和 global 级别的设置: mysql> select @@session.autocommit;+----------------------+| @@session.autocommit |+----......

摩云飞
2013/10/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Git —— 创建版本库和提交回退版本

二、 创建版本库 版本库又叫做仓库,简单理解就是一个目录,这个目录里面所有的文件都可以被Git管理起来,每个文件的修改、删除,Git都可以跟踪,便于追踪历史与还原。找到一个合适的位置,创...

lwenhao
26分钟前
2
0
guava cache使用介绍

今天在项目中发现大量使用guava cache提供缓存,觉得不错。 jvm堆大小为5G /** * * 占用JVM内存,内部数据结构类似于ConcurrentHashMap。因为JVM堆大小的限制,guava cac...

jack_peng
31分钟前
3
0
崛起于Springboot2.X之投票活动排行榜项目

简介:投票活动,用户只能一天投票一次,然后对参与投票的项目进行实时的排行功能。 架构:redis+mysql+springboot2.0.3+mybatis 不懂可以私信我哦 1、数据库建表 CREATE TABLE `t_dtb_prod...

木九天
39分钟前
2
0
logback源码分析-2、appender解析

源码基于logback 1.1.2 logback.xml文件内容如下 <?xml version="1.0"?><configuration scan="true" scanPeriod="30 seconds"> <property name="fileDir" value="/export/log/ingore......

924411018
45分钟前
2
0
【HAVENT原创】NodeJS 两个模块进行 RSA 加密解密(匹配Java RSA)

业务逻辑需要使用 NodeJS 进行公钥加密传输给 Java 后端进行私钥解密,但是默认 NodeJS 使用的 RSA padding 模式与 Java 的不一致,所以需要配置。 不啰嗦,上代码,分别用 crypto 和 node-r...

HAVENT
52分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部