【发布时间】:2009-02-19 08:57:01
【问题描述】:
我有一个结构简单的表格:
user_id、月份、余额、余额类型
我想为每个用户显示每月选择的余额类型:
user_id、月份、balance_1、balance_2、balance_3、balance_...
所以从数据来看:
ROW user_id month balance balance_type
1 5667 09 20 2068
2 5667 08 23 2068
3 5667 07 21 2068
4 5667 06 19 2068
5 5667 10 22 2068
6 5667 09 20 2069
7 5667 08 23 2069
8 5667 06 19 2069
9 5667 07 21 2069
10 5667 10 22 2069
11 5667 09 4199 2114
12 5667 06 4329 2114
13 5667 08 4365 2114
14 5667 10 4172,88 2114
15 5667 07 4000 2114
16 5667 10 572,1 6062
17 5667 08 598,44 6062
18 5667 07 548,4 6062
19 5667 06 593,51 6062
20 5667 09 575,69 6062
我会得到例如第 09 个月的数据:
user_id, month, balance_1, balance_2, balance_3, balance_4
5667 09 20 20 4199 575,69
在 SQL 或/和 PL/SQL 中对此的最佳解决方案是什么?
【问题讨论】:
-
如果您使用 11G,请参阅 PIVOT 子句:download.oracle.com/docs/cd/B28359_01/server.111/b28313/… 如果使用 9i 或 10g,请参阅:asktom.oracle.com/pls/asktom/…。