Sql 按多个字段之间的匹配进行分组
我有一张像这样的桌子:Sql 按多个字段之间的匹配进行分组,sql,ms-access,group-by,duplicates,Sql,Ms Access,Group By,Duplicates,我有一张像这样的桌子: | id | field1 | field2 | field3 | --------------------------------------------- | 1 | A | B | C | | 2 | E | F | G | | 3 | H | A | I | |
| id | field1 | field2 | field3 |
---------------------------------------------
| 1 | A | B | C |
| 2 | E | F | G |
| 3 | H | A | I |
| 4 | *null* | J | K |
| 5 | C | L | M |
---------------------------------------------
现在我要分组查找重复项。我写下这个问题:
SELECT FIRST(ID), COUNT(id)
FROM MyTable
GROUP BY field1
HAVING COUNT(id) > 1
这只返回字段1中的重复项。如果我按字段1、字段2、字段3写入分组,它会在三个字段中返回重复项。
但是我想从任何字段中找到重复项并将结果集分组。换句话说,这样的结果:
| Count | Value |
---------------------
| 2 | A |
| 2 | C |
---------------------
在一个简单的小组中是否可能?
这些值是非固定宽度的,可以为空。您可以创建联合查询:
SELECT Field1 AS FieldValue FROM MyTable
UNION ALL
SELECT Field2 AS FieldValue FROM MyTable
UNION ALL
SELECT Field3 AS FieldValue FROM MyTable
现在将此查询用作与原始查询类似的查询中的源