Oracle 10g에 키와 값의 쌍이 있는 테이블이 있고 이를 다음에 대한 열이 있는 테이블로 변환하려고 합니다. 각 고유 키와 각 행의 해당 값. 결과 테이블은 원본 테이블에 추가된 새로운 키-값 쌍에 따라 동적으로 조정되어야 합니다.
Oracle 11g에서는 동적 피버팅을 수행할 수 있는 PIVOT 작업을 도입했습니다.
select * from (select id, k, v from _kv) pivot(max(v) for k in ('name', 'age', 'gender', 'status'))
이 쿼리는 IN에 지정된 4개의 키 각각에 대한 열이 있는 테이블을 생성합니다.
Oracle 11g는 알 수 없는 열 제목을 처리할 수 있는 피벗 XML 옵션도 제공합니다.
select * from (select id, k, v from _kv) pivot xml(max(v) for k in (any))
이 쿼리는 XML 결과를 생성합니다. 여기서 각 열은 고유 키에 해당하고 관련 값은 XML 요소의 값으로 저장됩니다. value.
위 내용은 Oracle에서 행을 열로 동적으로 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!