Chinaunix首页 | 论坛 | 博客
  • 博客访问: 474588
  • 博文数量: 99
  • 博客积分: 3621
  • 博客等级: 中校
  • 技术积分: 1089
  • 用 户 组: 普通用户
  • 注册时间: 2010-06-22 16:29
文章存档

2012年(21)

2011年(28)

2010年(50)

分类: Mysql/postgreSQL

2012-06-12 11:01:57

show engine innodb status \G

点击(此处)折叠或打开

  1. *** (1) TRANSACTION:
  2. TRANSACTION 9CC3, ACTIVE 0 sec, OS thread id 2384 fetching rows
  3. mysql tables in use 2, locked 2
  4. LOCK WAIT 6 lock struct(s), heap size 1024, 12 row lock(s), undo log entries 2
  5. MySQL thread id 20, query id 138891 localhost 127.0.0.1 root Sending data
  6. DELETE FROM User WHERE ID IN (SELECT UserID FROM BusinessUser WHERE BusinessID=124001692)
  7. *** (1) WAITING FOR THIS LOCK TO BE GRANTED:
  8. RECORD LOCKS space id 0 page no 92015 n bits 88 index `PRIMARY` of table `df_demo`.`user` trx id 9CC3 lock_mode X waiting
  9. Record lock, heap no 14 PHYSICAL RECORD: n_fields 48; compact format; info bits 0
  10.  0: len 4; hex 80000788; asc ;;
  11.  .......................................................................

  12. *** (2) TRANSACTION:
  13. TRANSACTION 9CC0, ACTIVE 0 sec, OS thread id 1696 starting index read, thread declared inside InnoDB 370
  14. mysql tables in use 3, locked 3
  15. 9 lock struct(s), heap size 1024, 59 row lock(s), undo log entries 10
  16. MySQL thread id 21, query id 138887 localhost 127.0.0.1 root Sending data
  17. DELETE FROM UserOptions WHERE UserID IN (SELECT u.ID FROM User u JOIN BusinessUser bu ON u.ID=bu.UserID WHERE bu.BusinessID=124001691)
  18. *** (2) HOLDS THE LOCK(S):
  19. RECORD LOCKS space id 0 page no 92015 n bits 88 index `PRIMARY` of table `df_demo`.`user` trx id 9CC0 lock mode S locks rec but not gap
  20. Record lock, heap no 14 PHYSICAL RECORD: n_fields 48; compact format; info bits 0
  21.  0: len 4; hex 80000788; asc ;;
  22. ..........................................................................

  23. *** (2) WAITING FOR THIS LOCK TO BE GRANTED:
  24. RECORD LOCKS space id 0 page no 92015 n bits 88 index `PRIMARY` of table `df_demo`.`user` trx id 9CC0 lock mode S locks rec but not gap waiting
  25. Record lock, heap no 11 PHYSICAL RECORD: n_fields 48; compact format; info bits 0
  26.  0: len 4; hex 80000786; asc ;;
  27. ...........................................................................

  28. *** WE ROLL BACK TRANSACTION (1)
1:分析:
看看引起死锁的SQL执行计划:

点击(此处)折叠或打开

  1. mysql> explain select * FROM User WHERE ID IN (SELECT UserID FROM BusinessUser WHERE BusinessID=124001692);
  2. +----+--------------------+--------------+----------------+--------------------------------+-----------------+---------+------+------+-------------+
  3. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
  4. +----+--------------------+--------------+----------------+--------------------------------+-----------------+---------+------+------+-------------+
  5. | 1 | PRIMARY | User | ALL | NULL | NULL | NULL | NULL | 6095 | Using where |
  6. | 2 | DEPENDENT SUBQUERY | BusinessUser | index_subquery | idx_UserID_Type,idx_BusinessID | idx_UserID_Type | 5 | func | 1 | Using where |
  7. +----+--------------------+--------------+----------------+--------------------------------+-----------------+---------+------+------+-------------+
  8. 2 rows in set (0.00 sec)
User表全表扫描,会引起死锁。
 
2:解决
重写SQL,把IN改成JOIN,执行计划如下:

点击(此处)折叠或打开

  1. mysql> explain select a.* FROM User a inner join BusinessUser b on a.id=b.userid WHERE b.BusinessID=124001692;
  2. +----+-------------+-------+--------+--------------------------------+----------------+---------+--------------+------+-------------+
  3. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
  4. +----+-------------+-------+--------+--------------------------------+----------------+---------+--------------+------+-------------+
  5. | 1 | SIMPLE | b | ref | idx_UserID_Type,idx_BusinessID | idx_BusinessID | 5 | const | 1 | Using where |
  6. | 1 | SIMPLE | a | eq_ref | PRIMARY | PRIMARY | 4 | ng1.b.UserID | 1 | |
  7. +----+-------------+-------+--------+--------------------------------+----------------+---------+--------------+------+-------------+
  8. 2 rows in set (0.00 sec)
两表都用到索引了。
 
问题得到解决。
阅读(5053) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~