mysql查詢鎖表方式
mysql如何查詢鎖表
今天在做數(shù)據(jù)更新的時候,發(fā)現(xiàn)表中數(shù)據(jù)量不大,但是更新語句執(zhí)行很久都沒成功,經(jīng)過查詢后發(fā)現(xiàn)是表鎖死導(dǎo)致的,本文記錄一下鎖表解決步驟:
1.查看表是否被鎖
(1)直接在mysql命令行執(zhí)行:show engine innodb status。
(2)查看造成死鎖的sql語句,分析索引情況,然后優(yōu)化sql。
(3)然后show processlist,查看造成死鎖占用時間長的sql語句。
(4)show status like '%lock%'。
2.查看表被鎖狀態(tài)和結(jié)束死鎖步驟
(1)查看表被鎖狀態(tài):
show OPEN TABLES where In_use > 0; 這個語句記錄當(dāng)前鎖表狀態(tài)
(2)查詢進(jìn)程:
- show processlist查詢表被鎖進(jìn)程
- 查詢到相應(yīng)進(jìn)程killid
(3)分析鎖表的SQL:
- 分析相應(yīng)SQL,給表加索引,
- 常用字段加索引,表關(guān)聯(lián)字段加索引
(4)查看正在鎖的事物:
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS
(5)查看等待鎖的事物:
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS
3.mysql查詢鎖表指令速查
(1)查看當(dāng)前鎖超時時間
show variables like 'innodb_lock_wait_timeout';
(2)查看全局鎖超時時間
SHOW GLOBAL VARIABLES LIKE 'innodb_lock_wait_timeout';
(3)更改當(dāng)前鎖超時時間為120秒
SET innodb_lock_wait_timeout=120;
(4)更改全局鎖超時時間為120秒
SET GLOBAL innodb_lock_wait_timeout=120;
(5)查看鎖情況
show full processlist;
(6)殺死鎖的命令
KILL 具體的id
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL安裝時initializing database失敗的問題解決
本文主要介紹了MySQL安裝時initializing database失敗的問題解決,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-02-02MySQL權(quán)限USAGE和ALL PRIVILEGES的用法
本文主要介紹了MySQL權(quán)限USAGE和ALL PRIVILEGES的用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09php mysql連接數(shù)據(jù)庫實(shí)例
這篇文章主要介紹了php mysql連接數(shù)據(jù)庫實(shí)例,需要的朋友可以參考下2016-09-09