MySQL中使用UNION進行兩表合并,去重導致效率低下,請問如何優化
3 回答

紫衣仙女
TA貢獻1839條經驗 獲得超15個贊
不應用ALL關鍵字就可以刪除重復的行,例如:
select col1,col2 from t1
union
select col1,col2 from t2
union
select col1,col2 from t3;
多表聯合并保留所有的行:
select col1,col2 from t1
union all
select col1,col2 from t2
union all
select col1,col2 from t3;

浮云間
TA貢獻1829條經驗 獲得超4個贊
MySQL中使用UNION進行兩表合并,去重導致效率低下,請問如何優化
mysql> explain select * from wp_options limit 1\G;
id: 1
select_type: SIMPLE
table: wp_options
partitions: NULL
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 136
filtered: 100.00
Extra: NULL
1 row in set, 1 warning (0.01 sec)
mysql> show session status like 'Handler_read%';
添加回答
舉報
0/150
提交
取消