您的位置:首页 > 其它

distinct 多列详解

2016-04-08 22:09 232 查看

1.distinct 单列

select distinct(a) from tableA;


这个比较简单,没什么可说的。

2.distinct多列

select distinct a,b,c from tableA;


注意此时是将a,b,c三列所有不同的组合全部列出来,而不仅仅只是distinct a

相当于以下语句:

select a,b,c from tableA group by a,b,c


3.另外一种的distinct多列

其实这篇文章的最初需求如下:

想分别查某一张表的几个字段的distinct值

select distinct a from tableA;
select distinct b from tableA;
select distinct c from tableA;


这样是可以达到目的的。但是这样要写三条语句,不爽,想着用一条语句达到目的。

思考了一会,想到用union来解决这个问题。

select distinct(a) || ' a' from tableA
union all
select distinct(b) || ' b' from tableA
union all
select distinct(c) || ' c' from tableA


这样就达到了一条语句查询出所有结果的目的。后面拼接的字符串是为了标识这个值属于哪个字段。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: