[英]PHP MySQL Count Total Issue
我几乎完成了一个项目,这是我的最后一个问题。
我有一张表,我必须像这样使用 GROUP_CONCAT:
SELECT
GROUP_CONCAT(DISTINCT nextgenorder_companyname) AS nextgenorder_companyname,
GROUP_CONCAT(DISTINCT nextgenorder_company_entity) AS nextgenorder_company_entity,
GROUP_CONCAT(DISTINCT nextgenorder_ordernumber) AS nextgenorder_ordernumber,
GROUP_CONCAT(DISTINCT nextgenorder_deliverydate) AS nextgenorder_deliverydate
FROM nextgenorders2
WHERE nextgenorder_deliverydate='2020-11-11'
GROUP BY SUBSTRING_INDEX(REPLACE(nextgenorder_companyname, '/', ' '), ' ',1)
ORDER BY SUBSTRING_INDEX(REPLACE(nextgenorder_companyname, '/', ' '), ' ',1)
例如,上表的总数为 3。3 家公司总数。
我试过这个:
SELECT
count(DISTINCT nextgenorder_company_entity) as company,
nextgenorder_deliverydate as ShipDate
FROM nextgenorders2
WHERE nextgenorder_deliverydate='2020-11-11'
GROUP BY nextgenorder_deliverydate
但我得到的总数是 6。我刚刚介绍了 GROUP_CONCAT,我知道它是必要的,但我被卡住了。 我也试过这个:
SELECT GROUP_CONCAT(nextgenorder_companyname) AS nextgenorder_companyname,
GROUP_CONCAT(nextgenorder_deliverydate) nextgenorder_deliverydate
FROM
(
SELECT COUNT(*) Total
FROM nextgenorders2
WHERE nextgenorder_deliverydate='2020-11-11'
GROUP BY SUBSTRING_INDEX(REPLACE(nextgenorder_companyname, '/', ' '), ' ',1)
) q
您有一个表达式可以从数据库的列中提取“公司名称”。
将该表达式用于count(distinct)
:
SELECT count(DISTINCT SUBSTRING_INDEX(REPLACE(nextgenorder_companyname, '/', ' '), ' ',1)
) as company,
nextgenorder_deliverydate as ShipDate
FROM nextgenorders2
WHERE nextgenorder_deliverydate = '2020-11-11'
GROUP BY nextgenorder_deliverydate;
这是一个 db<>fiddle。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.