微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

postgreSQL查询 – 计算两列匹配的列值

我需要帮助创建一个SQL查询来计算在两个单独的列上分列的行.

这是我的表的DDL:

CREATE TABLE Agency (
  id SERIAL not null,city VARCHAR(200) not null,PRIMARY KEY(id)
);
CREATE TABLE Customer (
  id SERIAL not null,fullname VARCHAR(200) not null,status VARCHAR(15) not null CHECK(status IN ('new','regular','gold')),agencyID INTEGER not null REFERENCES Agency(id),PRIMARY KEY(id)
);

表中的样本数据

AGENCY
id|'city'
1 |'London'
2 |'Moscow'
3 |'Beijing'

CUSTOMER
id|'fullname'      |'status' |agencyid
1 |'Michael Smith' |'new'    |1
2 |'John Doe'      |'regular'|1
3 |'Vlad atanasov' |'new'    |2
4 |'Vasili Karasev'|'regular'|2
5 |'Elena Miskova' |'gold'   |2
6 |'Kim Yin Lu'    |'new'    |3
7 |'Hu Jintao'     |'regular'|3
8 |'Wen Jiabao'    |'regular'|3

我想按城市计算新客户,普通客户和黄金客户.

我需要单独计算(‘新’,’常规’,’黄金’).这是我想要的输出

'city'   |new_customers|regular_customers|gold_customers
'Moscow' |1            |1                |1
'Beijing'|1            |2                |0
'London' |1            |1                |0
几周前我一直在挣扎着.
这就是你所需要的.
SELECT 
  Agency.city,count(case when Customer.status = 'new' then 1 else null end) as New_Customers,count(case when Customer.status = 'regular' then 1 else null end) as Regular_Customers,count(case when Customer.status = 'gold' then 1 else null end) as Gold_Customers 
FROM 
  Agency,Customer 
WHERE 
  Agency.id = Customer.agencyID 
GROUP BY
  Agency.city;

原文地址:https://www.jb51.cc/postgresql/192721.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐