【经验随笔】MYSQL表加锁升级导致数据库访问失败
背景:有一次定位问题发现,在同一个session连接中对MYSQL部分表加锁,导致其它未加锁的表不能访问。
用Spring管理MYSQL数据连接,在多线程访问数据库的情况下容易出问题。一个线程中对部分表加锁了,尚未释放。其它线程访问同一数据库中其它未加锁的表,也会访问失败。
测试了一把:
步骤一、使用Navicat连接MYSQL数据库。编写如下4句SQL。
- LOCK TABLES tbl_A WRITE; 
- LOCK TABLES tbl_B WRITE; 
- DELETE FROM tbl_B; 
- UNLOCK TABLES; 
步骤二、先执行1、再执行3。报如下错误:[Err] 1100 - Table ‘tbl_B’ was not locked with LOCK TABLES。
步骤三、先执行1、再执行2、再执行3。正常。
步骤四、选两台电脑用Navicat连同一个库。在一台电脑上执行1、在另一台电脑上执行3,可以正常执行。说明加锁升级控制在一个连接会话中,不同的连接不受影响。
结论:在共享数据库会话连接的多线程程序中对数据库表加锁,务必对所有要访问的表都加锁。不同会话连接则不受这类锁升级的影响。
【经验随笔】MYSQL表加锁升级导致数据库访问失败的更多相关文章
- 【转载】Sqlserver强制密码过期导致数据库登录失败
		Sqlserver在设置登录账户信息的时候,有个复选框信息会被默认勾上,即强制实施密码策略,默认勾选上的还有强制密码过期.如果勾上了这个强制密码过期后,则你的账户密码在一定时间登录后会提示Sqlser ... 
- UNDO表空间损坏导致数据库无法OPEN
		在数据库undo表空间文件损坏.或者undo表空间文件缺失的情况下.无法打开数据库. 这两种情况都能够视为一种情况处理,解决方法一样. 场景:在23:10的时候新建一个undo表空间undotbs02 ... 
- PHP+Mysql————表单数据插入数据库及数据提取
		站点在进行新用户注冊时,都会将用户的注冊信息存入数据库中,须要的时候再进行提取.今天写了一个简单的实例. 主要完毕下面几点功能: (1)用户进行注冊,实现password反复确认,验证码校对功能. ( ... 
- 【转】MySQL表名大小写敏感导致的问题
		原文地址:https://blog.csdn.net/postnull/article/details/72455768 最近在项目中遇到一个比较奇怪的小问题.在开发过程中自己测试没有问题,但是提测后 ... 
- MySQL表名大小写敏感导致的问题
		最近在项目中遇到一个比较奇怪的小问题.在开发过程中自己测试没有问题,但是提测后,测试的同时在测试一个功能时报错了,日志是: Caused by: com.mysql.jdbc.exceptions ... 
- MySQL 表的约束与数据库设计
		DQL 查询语句 排序 # 单列排序 * 只按某一个字段进行排序,单列排序 # 组合排序 * 同时对多个字段进行排序,如果第1个字段相等,则按照第2个字段排序,依次类推 * 语法: # 具体操作 * ... 
- mysql表加锁、全表加锁、查看加锁、解锁
		单个表锁定: 格式: LOCK TABLES tbl_name {READ | WRITE},[ tbl_name {READ | WRITE},……] 例子: lock tables db_a.tb ... 
- mysql max_allowed_packet 设置过小导致记录写入失败
		mysql根据配置文件会限制server接受的数据包大小. 有时候大的插入和更新会受max_allowed_packet 参数限制,导致写入或者更新失败. 查看目前配置 show VARIABLES ... 
- XCode升级导致的IAP失败的问题
		应用提交苹果测试之前,一般都会在沙盒环境里进行测试充值.用沙盒的测试帐号进行充值的时候,服务端拿到苹果返回的receipt-data后,向苹果服务端进行校验的时候,如果返回错误码21007则再去沙盒环 ... 
随机推荐
- WinXP系统下Opencms的安装与配置
			1.WinXP系统下安装opencms (1)mysql已安装5.1.40 cmd命令行:mysql -uroot -proot (2)OpenCMS在安装时要求MySQL系统变量“max_al ... 
- Yii2 给iOS App写推送的接口
			public function actionApns() { //手机注册时候返回的设备号,在xcode中输出的,复制过来去掉空格 $deviceToken = '7217a01836349b194b ... 
- the c programing language 学习过程4
			4Functions and Program Structure scratch 刮擦 starting over from scratch从头开始 reside驻留 separately 分别的 f ... 
- Python使用Mysql官方驱动(取出dict类型的数据)
			简介 虽然Python有很多连接mysql的库,比如mysqldb, pymysql~这些都很方便,现在就教大家使用mysql的官方库来操作mysql. 安装 windows: 下载链接 选择自己的w ... 
- Luogu P1877 [HAOI2012]音量调节
			题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要改变一次音量.在演出开始之前,他已经做好一个列表,里面写着每首歌开始之前他想要改变的音量是多少. ... 
- 校验Linux程序是否被黑客修改
			一个黑客突破你的层层防御后,修改你的程序或者覆盖了你的工具时.确定一个已安装程序的所有文件,有没有被修改过的途径之一就是使用RPM包校验功能 如果图片排版有任何错误,欢迎访问我的简书www.jians ... 
- java 集合框架(三)Collection
			一.概述 Collection是集合框架的根接口.不同的集合具有不同的特性,比如有的集合可以有重复元素,有的不可以,有的可以排序,有的不可排序,如此等等,而Collection作为集合的根接口,它规范 ... 
- sqlserver中select造成死锁
			死锁过程: select语句使用非聚族索引查询产量信息,会对非聚族索引添加共享锁,由于非聚族索引上没有select的全部数据列,(所以会有书签查找出现,)需要查询产量表.查询产量表时,需要对产量表数据 ... 
- 关于我上传的activiti自定义流程demo的说明
			最近又收到了一些询问activiti的问题,其中好几个都是向我索要我上传的这个activiti自定义流程demo的数据库设计. 索要的多了,而我早就把这个库给删掉了,所以我便觉得有必要做一个说明: 我 ... 
- 3.3.2 PCI设备对不可Cache的存储器空间进行DMA读写
			在x86处理器和PowerPC处理器中,PCI设备对"不可Cache的存储器空间"进行DMA读写的过程并不相同.其中PowerPC处理器对"不可Cache的存储器空间&q ... 
