【PostgreSQL】PostgreSQL 语句使用的细节之 DISTINCT 与 GROUP BY

现在有一张表,其内容如下:

 id |  code  
----+--------
  1 | aaabbb
  2 | aaaccc
  3 | aaabbb
(3 rows)

现用两种方式,以 code 为依据,找出其中的所有非重复数据。

方式一:使用 DISTINCT

postgres=# SELECT DISTINCT code FROM test;
  code  
--------
 aaaccc
 aaabbb
(2 rows)

方式二:使用 GROUP BY

postgres=# SELECT code FROM test GROUP BY code;
  code  
--------
 aaaccc
 aaabbb
(2 rows)

在这里,GROUP BY 的使用只为分组,不为其他任何事。

到底应该使用哪一个呢?

自己刚开始的时候是有些懵的,因为实现的内容太像了,从结果看,使用哪一个都符合内容,但是除了语法外,还有一条简单的规则:所写的东西需要简单易懂。例如,看到方式一的代码,首先想到的就是,这是去除重复数据的;看到方式二,就想到这是分组的。所以,具体使用哪个,根据最简单的事理逻辑来写。

除了语法的可行性、复杂性、可阅读性外,又收获了一条重要的写代码的原则:事理逻辑。一般不会在这方面出错,因为往往事理逻辑和代码逻辑的出发点是一致的(就自己的知识范围而言),不过像 SQL 这种用于使用而非编程的语言,事理逻辑不同而结果相同的情况可能会很多。

是为记,己莫忘。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

狂杀傲骨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值