select distinct :当我们期望返回的数据不存在重复数据时(每一行的数据都不一样)
例如:表a
sql
select distinct a.* from a -- 可以查询出所有的信息
select distinct a.id from a -- 可以查询出id不同的信息,则还是全部数据的id列(1,2,3,4)
select distinct a.name from a -- 可以查询name不同的的信息,则是三条数据(qqq,www,eee)
由以上例子,可以很好的理解 distinct 关键字的作用。
还有一种作用,当select distinct 'XXX' from table where xxx不返回结果时,则结果为空,由返回结果时,结果被替换成XXX。
sql
select distinct 'XXX' from a where a.name = 'qqq' -- 结果列为XXX
select distinct 'XXX' from a where a.name = 'dfgd' -- 结果列为空