首页 > 解决方案 > 比较 postgres 数据库中的两列

问题描述

我对一个看似简单的问题感到有些困惑。我有一张桌子,例如,

CREATE TABLE cities (
     column_1 TEXT,
     column_2 TEXT);

这些表的内容看起来像

column_1  |  column_2
---------------------
Atlanta   |  Atlanta
Boston    |  Chicago
Chicago   |  Los Angeles
Seattle   |  Tacoma
NULL      |  Seattle

我可以运行什么查询来查看这两列,不管它们的顺序如何,返回两列匹配的位置?

我正在寻找的结果是:

column_1  |  column_2
---------------------
Atlanta   |  Atlanta
Chicago   |  Chicago
Seattle   |  Seattle

我努力了:

SELECT *
FROM cities
WHERE column_1 = column_2;

但这只会返回 EXACT 匹配项:

column_1  |  column_2
---------------------
Atlanta   |  Atlanta

标签: sqlpostgresqlcomparison

解决方案


你只需要一个自我加入:

SELECT c1.column_1, c2.column_2
FROM cities c1
JOIN cities c2
    ON c1.column_1 = c2.column_2

推荐阅读