怎么知道数据库表已经锁表了

怎么知道数据库表已经锁表了,第1张

可直接在mysql命令行执行:show engine innodb status\G

查看造成死锁的sql语句,分析索引情况,然后优化sql然后show processlist

show status like ‘%lock%’

show OPEN TABLES where In_use >0这个语句记录当前锁表状态

另外可以打开慢查询日志,linux下打开需在my.cnf的[mysqld]里面加上以下内容:

slow_query_log=TRUE(有些mysql版本是ON)

slow_query_log_file=/usr/local/mysql/slow_query_log.txt

long_query_time=3

select *from v$locked_object:可以获得被锁的对象的object_id及产生锁的会话sid。通过查询结果中的object_id,可以查询到具体被锁的对象。

扩展资料:

注意事项

也可以直接把这几个视图和表关联起来,在查询结果中直接得到“alter system kill session 'sid, serial#'”这样的方便的kill sessoin命令。

如果执行kill session命令后,锁并没有除掉,session依然存在。这种情况,通过select spid from v$process where addr in(select paddr from v$session where sid = &sid)查询到oracle会话在服务器上的pid,然后登陆到服务器上,执行kill -9 pid这样就能杀掉进程解锁了。

第一步,查看行锁使用情况,命令:

show statue like 'innodb_row_lock%'

如下图所示

第二步,创建数据库表monitor_amount,如下图所示:

第三步,查看innodb的状态,命令:

show innodb status \G

如下图所示:

第四步,向数据库表monitor_amount插入四条记录,如下图所示:

第五步,再次查看innodb状态,如下图所示:

第六步,可以利用删除表命令来停止查看,如下图所示:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9973631.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存