

新闻资讯
技术学院统计多字段组合次数应使用 GROUP BY 多列配合 COUNT(),如 SELECT city, industry, COUNT() FROM companies GROUP BY city, industry;非聚合字段须全在 GROUP BY 中,过滤分组结果用 HAVING,补全缺失组合需 CROSS JOIN 加 LEFT JOIN,高频组合字段应建顺序一致的联合索引。
要统计多个字段组合出现的次数,核心是用 GROUP BY 多个列 配合 COUNT(*),而不是嵌套或拼接字段——既清晰又高效。
数据库原生支持对多个字段同时分组,SQL 引擎会自动把值完全相同的行归为一组。例如统计「城市 + 行业」组合的公司数量:
报错(严格模式下)。GROUP BY industry, city 效果一致,但建议和 SELECT 顺序保持一致,便于阅读。WHERE 在分组前过滤单行数据;HAVING 在分组后过滤“组合组”。比如只看出现 ≥5 次的城市-行业组合:
默认 GROUP BY 只返回实际存在的组合。若需展示所有城市 × 所有行业(包括计数为 0 的),不能靠 GROUP BY 单独实现:
SELECT DISTINCT city FROM companies 和 SELECT DISTINCT industry FROM companies 构建完整组合集(可用 CROSS JOIN);COALESCE(COUNT(t.id), 0)。高频用于 GROUP BY 的字段组合(如 (city, industry)),建议创建联合索引: