亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL為什么慎用if not exists寫法

發布時間:2021-11-06 11:25:23 來源:億速云 閱讀:239 作者:小新 欄目:MySQL數據庫

這篇文章將為大家詳細講解有關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 ; 

按照如下時間軸執行 ,窗口二居然被阻塞了.


MySQL為什么慎用if not exists寫法

查看 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寫法”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

佛教| 漠河县| 小金县| 华亭县| 平武县| 孝昌县| 崇礼县| 孝感市| 张北县| 周宁县| 泰安市| 新龙县| 罗江县| 开平市| 金川县| 临桂县| 乐昌市| 上饶市| 招远市| 新巴尔虎右旗| 郑州市| 临澧县| 全椒县| 兴化市| 青岛市| 宁晋县| 仁布县| 荔浦县| 呼伦贝尔市| 扎兰屯市| 二连浩特市| 隆尧县| 洛扎县| 东源县| 阿尔山市| 康马县| 谷城县| 巴马| 尚志市| 罗江县| 长汀县|