步骤一:使用命令get snapshot来查询哪些进程锁了哪些表。
步骤二:使用命令force来断开这些进行了死锁的进程来。
步骤三: 使用命令list application查看是否已经断开了哪些进行了死锁的进程。
步骤一:使用命令get snapshot来查询哪些进程锁了哪些表。
步骤二:使用命令force来断开这些进行了死锁的进程来。
步骤三: 使用命令list application查看是否已经断开了哪些进行了死锁的进程。这样就可以解锁了
请按照下列方法 *** 作:1、依次单击【开始】→【设置】→【控制面板】,再依次双击【管理工具】→【组件服务】;
2、在“组件服务”页面左侧,依次双击展开【组件服务】→【计算机】→【我的电脑】,双击展开【DCOM配置】,此时在下面找到“PKDACNEW”组件;
3、右键单击PKDACNEW,选择【属性】→【标识】;
4、选择【下列用户】,输入数据库服务器上具有管理员权限用户的“用户名”和“密码”,单击【确定】即可。
可直接在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这样就能杀掉进程解锁了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)