PostgreSQL:多列精确匹配

PostgreSQL: Exact Match on Multiple Columns

背景

我有一个 table,其中包含多个 ID 字段,如下所示:

work_id TEXT DEFAULT NULL,
card_id TEXT DEFAULT NULL,
employee_id TEXT DEFAULT NULL,
school_id TEXT DEFAULT NULL

查找完全匹配

我需要找到所有这些字段完全匹配的行。这种比较的初始语法是:

SELECT * FROM table
WHERE
  work_id = card_id AND
  work_id = employee_id AND
  work_id = school_id;

查找任何不匹配的行

相反,我还需要找到所有这些字段都不完全匹配的行。这种比较的初始语法是:

SELECT * FROM table
WHERE
  work_id NOT = card_id OR
  work_id NOT = employee_id OR
  work_id NOT = school_id;

问题

有没有更简单的方法可以一次跨两列以上进行比较?是否有某种数组运算符可以在多个列中找到匹配或不匹配的值?

面向未来的代码

我问这个是因为如果比较的列数很多,这种类型的代码可能会变得笨拙且难以维护。例如,如果稍后我们向 table 添加另一个 ID 列,我将需要手动向比较逻辑添加一个新行以包含新列。

您可以使用复合值:

WHERE (work_id, work_id, work_id) <>
      (card_id, employee_id, school_id)

您可以对数组使用 ANY 或 ALL

SELECT * 
FROM the_table
WHERE work_id = all (array[card_id, employee_id, school_id])


SELECT * 
FROM the_table
WHERE work_id <> any (array[card_id, employee_id, school_id])