求优化一句sql语句,not in速度太慢了

selecttbl1.idfromtable1tbl1wheretbl1.idnotin(selecttbl2.idfromtable2tbl2);tbl1有9万条数据,... select tbl1.id from table1 tbl1 where tbl1.id not in (select tbl2.id from table2 tbl2);

tbl1有9万条数据,tbl2有3万条数据
展开
 我来答
小眼囿神
2012-09-28
知道答主
回答量:27
采纳率:0%
帮助的人:20.9万
展开全部
有俩种方法可以提高查询效率, 1、 用not exists 代替 not in , 这种发法没有改变查询数据的形式,所以可能效果不明显。 2、 利用索引查询, select tbl1.id from table1 tbl1 left join table2 tbl2 on tbl1.id = tbl2.id where tbl2.id = null; 这个是把table2表过滤,查询直接找索引。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
流浪云风
2012-09-28 · TA获得超过4315个赞
知道大有可为答主
回答量:1119
采纳率:69%
帮助的人:927万
展开全部
使用not exists 代替 not in
select tbl1.id from table1 tbl1 where not exists (select 1 from table2 tbl2 where tbl1.id = tbl2.id);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
老余数码
2018-12-19
知道答主
回答量:43
采纳率:0%
帮助的人:1.2万
展开全部
使用not exists 代替 not in
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
khg305387543
2012-09-28 · TA获得超过183个赞
知道小有建树答主
回答量:197
采纳率:0%
帮助的人:138万
展开全部
那就用 not exists
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
szm341
推荐于2017-11-25 · TA获得超过6726个赞
知道大有可为答主
回答量:5005
采纳率:100%
帮助的人:5127万
展开全部
两种方案:
1、分别给两表的id加索引(效果显著)
2、不用子查询
select tbl1.id from table1 tbl1 left join tbl2 on tbl1.id=tbl2.id
where tbl2.id is null
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式