首页 > 解决方案 > 如何对唯一查询进行复杂计数

问题描述

MySQL我正在尝试从/SQL数据库中获取特定类型的计数。该表有一列记录是 ID,第二列是另一个参考 ID。一些参考 ID 是整数,一些在其中包含文本。与此类似:

ID  | RefID
123 | 1234567
123 | 1234568
123 | 1234569
123 | ABC/US12/12345
123 | ABC/AA12/12345
123 | ABC/BB12/12345

如果数字是整数,则代表美国。对于文本 ID,“ABC”部分始终相同,但“AA”和“BB”代表国家代码。有时它是“美国”,例如“ABC/US12/12345”。

对于每个 ID,我想要计算其各自参考 ID 的唯一国家/地区。我想这将使用DISTINCT RefIDand 看起来像这样:

SELECT ID, count(DISTINCT RefID)
FROM TABLE
GROUP BY ID;

除了count(DISTINCT RefID)我希望 DISTINCT 与SUBSTRING(RefID, 5, 2)=“US” 的任何整数 RefID 或 RefID 相关,否则DISTINCT应该与 RefID 相关,而不是简单地DISTINCT(SUBSTRING(RefID, 5, 2))。所以上面数据的计数是3.

谁能给我一个关于这种类型的函数被称为什么或如何完成这个的开始?

标签: mysqlsqldistinct

解决方案


你似乎想要这样的东西:

SELECT ID,
       COUNT(DISTINCT CASE WHEN RefID REGEXP '^[0-9]+$' THEN 'US'
                           WHEN RefID LIKE '%/US%' THEN 'US'
                           ELSE RefID
                      END)
FROM CONTINUITYCHILD_P
GROUP BY ID;

如果您需要从其他RefIDs 中提取国家/地区,则可能需要额外的逻辑。


推荐阅读