今天去面试被这个问题问挂啦,只怪数据库知识太弱,准备买本高性能MYSQL补补,多看看沈询的视频。 现总结下如何解决这个问题:
问题分析和思考:
(1)现在数据库的事务隔离级别都是快照级别(MVCC),理论上写写操作是不是不会产生死锁的?
(2)表锁了,查看session,关联出SQL,然后执行看看,基本也可以定位下问题。
1.临时方案1:”查询是否是SQL的问题,查看锁表情况并处理锁表“ 或 “调整MYSQL事务隔离级别” 或 “重建索引表空间 ”或 “查询空间是否足够”
问题分析和思考:
(1)现在数据库的事务隔离级别都是快照级别(MVCC),理论上写写操作是不是不会产生死锁的?
(2)表锁了,查看session,关联出SQL,然后执行看看,基本也可以定位下问题。
1.临时方案1:”查询是否是SQL的问题,查看锁表情况并处理锁表“ 或 “调整MYSQL事务隔离级别” 或 “重建索引表空间 ”或 “查询空间是否足够”
/*
*locked
*query locked object and analyse reason,kill it
*
*/
select 'alter system kill session ''' || SID || ',' || SERIAL# || ''';'
from (select distinct a.sid,
a.Serial#,
status,
machine,
LOCKWAIT,
logon_time
from v$session a, v$locked_object b
where (a.status &