Background Image
질의작성
2009.06.24 02:42

pivot() 간략하게 구현하기

조회 수 23426 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
CUBRID에서는 pivot()을 지원하지는 않지만 object 개념의 set 을 이용하여 간략하게 pivot()을 구현할 수 있다.
아래에서 CUBRID 에서 제공하는 시스템 카다로그 테이블중 테이블 정보(db_class), 필드정보(db_attribute)를 이용하여 각 테이블 별로 필드명을 출력하도록 만들어 보았다.
select class_name, list(select attr_name from db_attribute a where a.class_name = c.class_name) from db_class c
와 같이 질의를 하면 아래와 같은 결과를 볼수있다. 
'glo'                 {'header_size', 'holder_obj', 'unit_size'}
'glo_holder'       {'glo', 'lock', 'name'}
'glo_name'        {'holder_ptr', 'pathname'}
'db_serial'         {'att_name', 'class_name', 'current_val', 'cyclic', 'increment_val', 'max_val', 'min_val', 'name', 'owner', 'started'}
'db_stored_procedure_args'  {'arg_name', 'data_type', 'index_of', 'mode', 'sp_name'}
'db_stored_procedure'  {'arg_count', 'lang', 'owner', 'return_type', 'sp_name', 'sp_type', 'target'}
'db_partition'        {'class_name', 'partition_class_name', 'partition_expr', 'partition_name', 'partition_type', 'partition_values'}
...
첫번째가 테이블명(class_name)이고, 두번째가 테이블의 필드명들을 pivot 형태로 만든 것이다.
pivot 된 결과는 {}로 감싸져있고 각 데이터들은 , 로 구분되어있으니, 이점을 감안하여 사용하면 된다.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
34 질의작성 각 테이블 PK 유무 확인 쿼리문 엄기호 2016.01.01 9012
33 질의작성 synonym에 대하여 김민종 2023.09.07 257
32 질의작성 subquery를 이용한 튜닝예제 file 김창휘 2016.12.27 3322
31 질의작성 select 결과중 몇개만 가져오는 방법 admin 2008.11.21 19917
» 질의작성 pivot() 간략하게 구현하기 남재우 2009.06.24 23426
29 질의작성 loose index scan을 활용한 효과적인 쿼리 튜닝 방안 박세훈 2017.06.01 2409
28 질의작성 join update 처리방법입니다.(연관성 있는 테이블을 조인하여 처리하는 UPDATE 구문) 권호일 2012.11.30 20393
27 질의작성 group_concat(문자열 그룹처리) 함수 사용하기 권호일 2016.06.29 28241
26 질의작성 group by 사용 방법 및 여러 필드중 하나의 필드에 대하여만 group by 처리 방법 남재우 2010.02.26 21711
25 질의작성 function based index 대체 방법 남재우 2010.07.01 13420
24 질의작성 VALUES 절 활용하기 황영진 2020.05.13 814
23 질의작성 UPDATE에서 조인을 통해, 결과값 수정하는 방법 박동윤 2016.12.27 7175
22 질의작성 SQL튜닝 - 인덱스 활용 사례 권호일 2015.06.04 12014
21 질의작성 Oracle UTL_ENCODE.TEXT_ENCODE를 CUBRID로 변환하기 김창휘 2016.03.21 4646
20 질의작성 ORACLE 테이블 및 컬럼 COMMENT 일광등록 스크립트 1 김창휘 2016.04.04 9335
19 질의작성 ORACLE TRIGGER를 CUBRID TRIGGER로 변환하기 김창휘 2015.12.31 6460
18 질의작성 MERGE INTO 사용 예제 ( INSERT, UPDATE문을 1개의 쿼리로 실행 ) 권호일 2015.05.01 21254
17 질의작성 LIKE 검색에서 INDEX_SCAN사용 하기 file janus 2009.04.17 21809
16 질의작성 JAVA_SP를 이용해서 정규표현식을 이용해서 치환을 하자. file 성진 2017.10.10 1325
15 질의작성 Integer 컬럼의 결과에 + or – 연산을 할 때 주의해야 할 점 웁쓰 2009.12.31 13493
Board Pagination Prev 1 2 3 4 Next
/ 4

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales