看看我们的 Query 的执行计划:
1 sky@localhost : example 11:17:04> explain select m.subject msg_subject, c.content msg_content 2 3 -> from user_group g,group_message m,group_message_content c 4 5 -> where g.user_id = 1 6 7 -> and m.group_id = g.group_id 8 9 -> and c.group_msg_id = m.id\G 10 11 *************************** 1. row *************************** 12 13 id: 1 14 15 select_type: SIMPLE 16 17 table: g 18 19 type: ref 20 21 possible_keys: user_group_gid_ind,user_group_uid_ind,user_group_gid_uid_ind 22 23 key: user_group_uid_ind 24 25 key_len: 4 26 27 ref: const 28 29 rows: 2 30 31 Extra: 32 33 *************************** 2. row *************************** 34 35 id: 1 36 37 select_type: SIMPLE 38 39 table: m 40 41 type: ref 42 43 possible_keys: PRIMARY,idx_group_message_gid_uid 44 45 key: idx_group_message_gid_uid 46 47 key_len: 4 48 49 ref: example.g.group_id 50 51 rows: 3 52 53 Extra: 54 55 *************************** 3. row *************************** 56 57 id: 1 58 59 select_type: SIMPLE 60 61 table: c 62 63 type: ref 64 65 possible_keys: idx_group_message_content_msg_id 66 67 key: idx_group_message_content_msg_id 68 69 key_len: 4 70 71 ref: example.m.id 72 73 rows: 2 74 75 Extra:
我们可以看出,MySQL Query Optimizer 选择了 user_group 作为驱动表,首先利用我们传入的条件 user_id 通过 该表上面的索引 user_group_uid_ind 来进行 const 条件的索引 ref 查找,然后以 user_group 表中过滤出来的结果集的 group_id 字段作为查询条件,对 group_message 循环查询,然后再通过 user_group 和 group_message 两个表的结果集中的 group_message 的 id 作为条件 与 group_message_content 的 group_msg_id 比较进行循环查询,才得到最终的结果。没啥特别的,后一个引用前一个的结果集作为条件,实现过程可以通过下图表示:
下面的我们调整一下 group_message_content 去掉上面的 idx_group_message_content_msg_id 这个索引,然后再看看会是什么效果:
1 sky@localhost : example 11:25:36> drop index idx_group_message_content_msg_id on group_message_content; 2 3 Query OK, 96 rows affected (0.11 sec) 4 5 sky@localhost : example 10:21:06> explain 6 7 -> select m.subject msg_subject, c.content msg_content 8 9 -> from user_group g,group_message m,group_message_content c 10 11 -> where g.user_id = 1 12 13 -> and m.group_id = g.group_id 14 15 -> and c.group_msg_id = m.id\G 16 17 *************************** 1. row *************************** 18 19 id: 1 20 21 select_type: SIMPLE 22 23 table: g 24 25 type: ref 26 27 possible_keys: idx_user_group_uid 28 29 key: idx_user_group_uid 30 31 key_len: 4 32 33 ref: const 34 35 rows: 2 36 37 Extra: 38 39 *************************** 2. row *************************** 40 41 id: 1 42 43 select_type: SIMPLE 44 45 table: m 46 47 type: ref 48 49 possible_keys: PRIMARY,idx_group_message_gid_uid 50 51 key: idx_group_message_gid_uid 52 53 key_len: 4 54 55 ref: example.g.group_id 56 57 rows: 3 58 59 Extra: 60 61 *************************** 3. row *************************** 62 63 id: 1 64 65 select_type: SIMPLE 66 67 table: c 68 69 type: ALL 70 71 possible_keys: NULL 72 73 key: NULL 74 75 key_len: NULL 76 77 ref: NULL 78 79 rows: 96 80 81 Extra: Using where; Using join buffer
|