繁体   English   中英

PostgreSQL查询两个表之间的相等性

[英]PostgreSQL query for equality between two tables

我有两个表A和B,我想查询一个查询:仅当两个表相同时才返回TRUE(我表示A中的每一行都出现在B中,反之亦然,无论行顺序如何)

我使用了关键字EXCEPT,但是在很多情况下它不起作用

谢谢你的帮助。

select * from tablea except all select * from tableb

从tablea返回tableb中不存在的所有行。

反过来做

select * from tableb except all select * from tablea

返回tableb中不存在的所有行。

因此,现在我们可以:

select count(*) from ( select * from tablea except all select * from tableb ) x;

获取表中“坏”行的数量,并:

select count(*) from ( select * from tableb except all select * from tablea ) x;

获取表b中“不良”行的计数。

如果两个计数均为0,则表是相同的。并且由于两个计数均不能小于零,因此我们可以测试计数之和是否为0:

select 0 = ( select count(*) from ( select * from tablea except all select * from tableb ) x ) + ( select count(*) from ( select * from tableb except all select * from tablea ) x );

暂无
暂无

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

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