多表联查 on or 索引失效优化
案例:
select *
from A a left join B b on a.id = b.id or concat(a.id,'_1') = b.id
left join C c on a.username = b.username
where a.sex = '男'
优化:
select
a.字段,
b.字段,
ifnull(b.字段,b2.字段) as 字段,//a表对应的字段值在b和b2表中不是同时存在的情况,判断获取
a.字段,
......
from A a left join B b on a.id = b.id left join B b2 concat(a.id,'_1') = b2.id
left join C c on a.username = b.username
where a.sex = '男'
总结:
1.可以使用union( all)函数,把or函数的数据分开查询,然后通过union( all)函数合并,注意:union all函数比union 函数执行速度更快一点。union all表示合并数据(不去重),union表示合并数据(去重,去重原因是:一行数据完全一致,才算是同一条数据,进行去重)
2.直接再次把副表进行对应的join,然后如果字段对应的数据值需要在两个副表中获取,则需要进行判断获取。例如上面优化SQL中的ifnull()函数