通常,当寻找某些其他表格中未显示的项目时,我们可以使用:
select * from gifts where giftID not in (select giftID from sentgifts);
要么
select * from gifts where giftID not in (select distinct giftID from sentgifts);
第二行添加了“ distinct”,因此结果表更小,也可能使搜索“ not in”的速度也更快.
因此,使用“区别”不是可取的吗?通常,在这种情况下,我看不到它在子查询中使用.使用它有优点还是缺点?谢谢.
最佳答案
当您对结果调用DISTINCT时,它需要对列表进行扫描才能找到并删除重复项.这是一个缓慢的操作,如果没有查询,整个查询很有可能会更快.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。