分享更有价值
被信任是一种快乐

MySQL为什么慎用if not exists写法

文章页正文上

这篇文章将为大家详细讲解有关MySQL为什么慎用if not exists写法,小编免费主机域名觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

版本 5.6.14

环境
CREATE TABLE `t1` (
`id` int(11) NOT NULL,
`batchid` int(11) DEFAULT NULL,
`state` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4

INSERT INTO `t1` (`id`,`batchid`,`state`) VALUES (1,1,1);
INSERT INTO `t1` (`id`,`batchid`,`state`) VALUES (2,1,1);

drop procedure if exists p;
delimiter $$
CREATE PROCEDURE `p`()
begin
if not exists (select * from t1 where id=1) then
select ‘id=1 not exists免费主机域名‘;
end if;
end $$
delimiter ;

按照如下时间轴执行 ,窗口二居然被阻塞了.

查看 show engine innodb status;
发现如下信息:

—TRANSACTION 15252974, ACTIVE 2 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 2 lock struct(s), heap size 376, 1 row lock(s)
MySQL thread id 38, OS thread handle 0x1d88, query id 4663 localhost 127.0.0.1 root statistics
select * from t1 where id=1
LIMIT 0, 1000
for update
——- TRX HAS BEEN WAITING 2 SEC FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 2344 page no 3 n bits 72 index `PRIMARY` of table `mvbox`.`t1` trx id 15252974 lock_mode X locks rec but not gap waiting
Record lock, heap no 2 PHYSICAL RECORD: n_fields 5; compact format; info bits 0
0: len 4; hex 80000001; asc ;;
1: len 6; hex 000000e8bdc4; asc ;;
2: len 7; hex 030003c0100437; asc 7;;
3: len 4; hex 80000001; asc ;;
4: len 4; hex 80000001; asc ;;

——————
—TRANSACTION 15252973, ACTIVE 15 sec
2 lock struct(s), heap size 376, 1 row lock(s)
MySQL thread id 36, OS thread handle 0x35c, query id 4615 localhost 127.0.0.1 root cleaning up

过程中 if not exists 的查询居然上了锁..关于“MySQL为什么慎用if not exists写法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

相关推荐: Python如何连接Mysql实现图书借阅系统

本篇内容主要讲解“Python如何连接Mysql实现图书借阅系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python如何连免费云主机、域名接Mysql实现图书借阅系统”吧! 我们在这里需要三张表,一张用户表,…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册