猿问

mysql百万数据查询 用什么代替in,该如何处理?

mysql百万数据查询 用什么代替in,该如何处理


智慧大石
浏览 7803回答 3
3回答

心有法竹

mysql百万数据查询用exists 代替 in 是一个好的选择:select num from a where num in(select num from b)&nbsp;用下面的语句替换:select num from a where exists(select 1 from b where num=a.num)SQL查询语句优化方法:&nbsp;1、应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描。2、对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。3、应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:select id from t where num is null可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:select id from t where num=04、尽量避免在 where 子句中使用 or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描,如:select id from t where num=10 or num=20可以这样查询:select id from t where num=10union allselect id from t where num=205、下面的查询也将导致全表扫描:(不能前置百分号)select id from t where name like ‘%c%’若要提高效率,可以考虑全文检索。

不负相思意

这个主键ID其实已经是有建立了索引的了,而在IN查询当中并没有用到而已,其实你可以试试IN里的id少些时,是会用到索引的,但当IN里的id占据全表的大部分数据量时,mysql采用的时全表扫描。在这个时候可以考虑:1.split返回临时表进行表连接,2.使用缓存遍历
随时随地看视频慕课网APP
我要回答