Mysql的select in会自动过滤重复的数据

默认使用 SELECT 语句;

 当加上in范围后,结果如下图:

in范围内的数据,如果有重复的,只会选择第一个数据。

所以如果不是直接使用SQL语句来查询,而是在代码中来查询时,记得使用 distinct 关键字

如:

select id, name from table1 where ref_id in (
     select id from table2   
)

其实是相当于:

select id, name from table1 where ref_id in (
     select distinct id from table2   
)

因为table2中的id可能会存在重复的情况。

 

posted @ 2018-01-03 00:36  一菲聪天  阅读(6754)  评论(0编辑  收藏  举报