繁体   English   中英

使用选择不同的多个列,但所有列都必须是不同的

[英]using select distinct with multiple columns but all columns musnt be distinct

我需要表中的所有列,但两列必须是不同的。 我使用了这段代码,但是它检查了所有列,但是我只需要将其中的两个分开即可。 我该如何满足?

select distinct a.personalId, a.fileId, a.name, a.surname, a.address from my_table a

如果使用以下代码,则无法获得其他列:

select distinct a.personalId, a.fileId from my_table a

Postgresql支持DISTINCT ON语法: http : //www.postgresql.org/docs/current/interactive/sql-select.html

select distinct on (a.personalId, a.fileId) a.personalId, a.fileId, a.name, a.surname, a.address
from my_table a

看到Oracle等同于Postgres的DISTINCT ON吗? 有关如何在Oracle中执行此操作。

如果其他列不同,该怎么办? 数据库应如何选择要显示的值? 答案是“不能”,并且因为不能,所以没有语法可以这样做(这是一个逻辑错误)。

MySQL确实有扩展,它将随机选择值。

select a.personalId, a.fileId, a.name, a.surname, a.address
from my_table a
group by a.personalId, a.fileId

但是我不建议依赖于此。 您需要重新考虑所使用的逻辑。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM