社区所有版块导航
Python
python开源   Django   Python   DjangoApp   pycharm  
DATA
docker   Elasticsearch  
aigc
aigc   chatgpt  
WEB开发
linux   MongoDB   Redis   DATABASE   NGINX   其他Web框架   web工具   zookeeper   tornado   NoSql   Bootstrap   js   peewee   Git   bottle   IE   MQ   Jquery  
机器学习
机器学习算法  
Python88.com
反馈   公告   社区推广  
产品
短视频  
印度
印度  
Py学习  »  DATABASE

MySQL联合生成两列

Knox • 3 年前 • 1372 次点击  

理想情况下,下面的代码应该输出一列中的男性数量和另一列中的女性数量。没有错误,但它只为男性创建一列,并将男性和女性的金额都放在该列下。

SELECT COUNT(Gender) AS Males FROM Customers 
JOIN Rents ON Rents.Customers_Cid= Customers.Cid
JOIN Cars ON Cars.CarId=Rents.Cars_CarId 
WHERE Make='Dodge' AND Gender='M'
UNION 
SELECT COUNT(Gender) AS Females FROM Customers 
JOIN Rents ON Rents.Customers_Cid= Customers.Cid
JOIN Cars ON Cars.CarId=Rents.Cars_CarId 
WHERE Make='Dodge' AND Gender='F';
Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/130103
 
1372 次点击  
文章 [ 1 ]  |  最新文章 3 年前
Tim Biegeleisen
Reply   •   1 楼
Tim Biegeleisen    3 年前

对单次传递查询使用条件聚合:

SELECT SUM(cu.Gender = 'M') AS Males,
       SUM(cu.Gender = 'F') AS Females
FROM Customers cu
INNER JOIN Rents r ON r.Customers_Cid = cu.Cid
INNER JOIN Cars ON c.CarId = r.Cars_CarId 
WHERE c.Make = 'Dodge';

为了让你的工会方法发挥作用,你只需为性别选择一个计算列,例如。

SELECT COUNT(Gender) AS Num, 'M' AS Gender
...
UNION ALL
SELECT COUNT(Gender), 'F'