SQL:查询一个表的字段在另一个表里是否存在;怎么写最优化;

查询一个表的字段在另一个表里是否存在;现在的写法是:SELECTfield1FROMtable1WHEREfield1NOTIN(SELECTfield1FROMtabl... 查询一个表的字段在另一个表里是否存在;现在的写法是:
SELECT field1 FROM table1
WHERE field1 NOT IN
(SELECT field1 FROM table2)

因为数据量大,所以跑起来特别慢,能否有优化的办法;
展开
 我来答
chen_hongyang
2013-07-19 · TA获得超过5446个赞
知道大有可为答主
回答量:2790
采纳率:91%
帮助的人:838万
展开全部
select count(*) from 表1 where 列1 in (select 列1 from 表2 )
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
厍曼冬6o
2013-07-19 · TA获得超过1569个赞
知道小有建树答主
回答量:1336
采纳率:0%
帮助的人:1191万
展开全部
SELECT field1 FROM table1 a
WHERE not exists(select 1 from FROM table2 where field1=a. field1)
同时,在field1字段添加索引
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式