在SQL中,当在另一个表中查找“未显示”的某些项时,为什么在子查询中不使用“ Distinct”?

通常,当寻找某些其他表格中未显示的项目时,我们可以使用:

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时,它需要对列表进行扫描才能找到并删除重复项.这是一个缓慢的操作,如果没有查询,整个查询很有可能会更快.

相关文章

在正式开始之前,我们先来看下 MySQL 服务器的配置和版本号信...
> [合辑地址:MySQL全面瓦解](https://www.cnblogs.c...
物理服务机的CPU、内存、存储设备、连接数等资源有限,某个时...
1 回顾 上一节我们详细讲解了如何对数据库进行分区操作,包括...
navicat查看某个表的所有字段的详细信息 navicat设计表只能一...
文章浏览阅读4.3k次。转载请把头部出处链接和尾部二维码一起...