我有2代表这样行作为列的sql
表1
profile
--------
id
---
1 | XXX
2 | zzz
表2
profile_details
-----------------
id | K | V
---------------------------
1 | first_name | XXX
1 | last_name | YYY
1 | gender | female
2 | name | zzzzz
2 | gender | male
2 | phone | 8999xxxx
2 | location | india
2 | spoken_language | hindi
我使用此查询来获取行作为COLS
select profiles.id,
max(decode(k, 'first_name', v, NULL)) first_name,
max(decode(k, 'last_name', v, null))as last_name ,
max(decode(k, 'gender', v, NULL)) gender
from profile_details , profiles
where
profile_details.id = profiles.id
and
profile_details.id=1
group by profiles.id
抓到我
id | first_name| last_name | gender
--------------------------------------------
1 | XXX | YYY | female
这可以将行作为列提取。但是如何将此查询更改为动态包含列,因为K值可能是任何可能的值。
前,为ID 2,它应该是
id | name | gender | mobile | location | spoken_language
------------------------------------------------------------------
2 | zzz | male | 8999xxxx | india | hindi
感谢 V
你的问题的简单答案是“不”。 SQL语句必须明确列出正在返回的列。扩展的答案是:你知道关于动态SQL的任何信息吗? – 2013-03-20 13:49:21
我不知道:-( – 2013-03-20 14:36:23