如何计算所选列在查询结果中有多少个唯一字段


How do I count how many unique fields a selected column has in query result

我有一个查询来获取网络表单提交。 下面是查询及其返回的内容。我需要它返回重复 sid 的计数,以获取满足两个数据变量的所有提交的计数。意思是,我希望它返回 4,有什么建议吗?

SELECT sid, data
FROM webform_submitted_data
INNER JOIN node
ON webform_submitted_data.nid=node.nid
WHERE webform_submitted_data.nid= 15 AND webform_submitted_data.cid = 6 AND webform_submitted_data.data = 'male' OR webform_submitted_data.data = 'yes' AND webform_submitted_data.nid= 15 AND webform_submitted_data.cid= 15;

sid | Data
-----------
86  | male
86  | yes
87  | yes
88  | yes
90  | yes
91  | male
91  | yes
92  | male
92  | yes
93  | male
93  | yes
94  | yes

您可以按 sid 分组并计算数据:

SELECT sid, COUNT(*) as nb_sid
FROM webform_submitted_data
INNER JOIN node
ON webform_submitted_data.nid=node.nid
WHERE webform_submitted_data.nid= 15
    AND webform_submitted_data.cid = 6 
    AND webform_submitted_data.data = 'male' OR webform_submitted_data.data = 'yes'
    AND webform_submitted_data.nid= 15
    AND webform_submitted_data.cid= 15
GROUP BY sid;

如果需要,可以在 where 子句中筛选nb_sid。如果您确实需要,您还可以使用 group_concat 获取数据中的值。