Oracle 和新版 Mysql 里有 pivot 实现行列转置,但实际处理数据时,会碰到一些更复杂的转置情况,pivot 也搞不定,比如:
想转置成:
这个难点在于事先不知道有多少种收入来源,而且每个人的收入来源种类各不相同。先得计算出种类个数,根据个数动态生成表结构,然后按照顺序填充每个人的多个收入数据。
SQL 的计算过程不提倡分步,对集合操作支持的也不彻底,很难应付这种多步骤复杂计算。
如果用集算器的 SPL 语言来处理,就能轻松实现:
A
B
1
=connect("db")
=A1.query("select * from Income")
2
=B1.group(Name)
=A2.max(~.len())
3
=create(Name,${B2.("Source"+string(~)+",Income"+str