私はこのような2つのテーブルを持っています
表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
このクエリを使用して、行を列としてフェッチします
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