在SQL中,可以使用CASE语句将多个列进行数据透视,而不需要使用聚合函数。下面是一个例子:
假设有一个名为"orders"的表,包含以下列:order_id, customer_id, product_id, quantity, price。 我们想要透视该表,以显示每个顾客(customer_id)购买的每个产品(product_id)的总数量(quantity)和总金额(quantity * price)。
以下是一个使用CASE语句进行数据透视的例子:
SELECT customer_id,
SUM(CASE WHEN product_id = 1 THEN quantity ELSE 0 END) AS product_1_quantity,
SUM(CASE WHEN product_id = 1 THEN quantity * price ELSE 0 END) AS product_1_amount,
SUM(CASE WHEN product_id = 2 THEN quantity ELSE 0 END) AS product_2_quantity,
SUM(CASE WHEN product_id = 2 THEN quantity * price ELSE 0 END) AS product_2_amount
FROM orders
GROUP BY customer_id;
在上面的例子中,我们使用了CASE语句来创建四个不同的列:product_1_quantity,product_1_amount,product_2_quantity和product_2_amount。我们根据product_id的值,将quantity和quantity * price添加到相应的列中。最后,我们使用GROUP BY子句按customer_id进行分组。
这样,我们就得到了每个顾客购买的每个产品的总数量和总金额的透视数据。
上一篇:不强制高度,填充剩余空间
下一篇:不强制推送的变基