Background Image
조회 수 10921 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

한 Row에 들어 있는 값을 여러 Row로 쿼리문 만들기

1) 한 Row의 구분자가 ','로 되어 있는 경우

2) ','개수 Row + 1개의 Row의 갯수 쿼리문 만들기


CREATE TABLE tb_list(idx integer not null primary key,
                         code_id varchar2(10),
                         code varchar2(100));
insert into tb_list(idx, code_id, code) values(1, '1012111300', '3,2,3,4,1,1,1,2,3,4,,4,2,3,1,2,4,1,2,1,3,4,3,2,2,3,2,3,4,1,1,1,2,3,4,,4,2,3,1');
CREATE TABLE tb_cnt(cnt_no INTEGER NOT NULL PRIMARY key);
INSERT INTO tb_cnt(cnt_no)
values(1) ,(2)       ,(3)       ,(4)       ,(5)       ,(6)       ,(7)       ,(8)       ,(9)       ,(10)      ,(11)      ,(12)      ,(13)      ,(14)      ,(15)    
,(16)      ,(17)      ,(18)      ,(19)      ,(20)      ,(21)      ,(22)      ,(23)      ,(24)      ,(25)      ,(26)      ,(27)      ,(28)      ,(29)      ,(30)    
,(31)      ,(32)      ,(33)      ,(34)      ,(35)      ,(36)      ,(37)      ,(38)      ,(39)      ,(40)   
;


4) 쿼리문
SELECT a.idx, a.code_id
         , REPLACE(substring_index(a.code,',',b.cnt_no), SUBSTRING_INDEX(a.code,',',b.cnt_no-1)||',','') AS answer
FROM (       
SELECT idx
         , code_id
         , code
FROM t_list ) a, tb_cnt b
WHERE code_id = '1012111300'
      AND b.cnt_no <= LENGTH(a.code) - LENGTH(REPLACE(a.code, ',','')) +1

  • ?
    성진 2016.12.10 00:17 Files첨부 (1)
    위에는 오라클 예제이고

    CUBRID 예제는 다음과 같습니다. 또한 추가 조인이 필요 없게 만들었습니다.

    SELECT

        code,

        LEVEL,

        REPLACE(REPLACE(SUBSTRING_INDEX(code,',',LEVEL), SUBSTRING_INDEX(code,',',LEVEL -1),''),',','') code_split

    FROM (SELECT '3,2,3,4,1,1,1,2,3,4,,4,2,3,1,2,4,1,2,1,3,4,3,2,2,3,2,3,4,1,1,1,2,3,4,,4,2,3,1' AS code) Z

    CONNECT BY LEVEL <= LENGTH(code) - LENGTH(REPLACE(code,',','')) - 1;



    split.png


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
219 운영관리 큐브리드 + 아파치 + php 설치 및 연동 1 하하보이 2010.12.15 21900
218 질의작성 LIKE 검색에서 INDEX_SCAN사용 하기 file janus 2009.04.17 21806
217 질의작성 테이블 컬럼 변경 및 추가 정만영 2016.02.29 21777
216 질의작성 group by 사용 방법 및 여러 필드중 하나의 필드에 대하여만 group by 처리 방법 남재우 2010.02.26 21709
215 응용개발 응용프로그램에서 질의 처리시 commit/rollback 처리 문제 admin 2008.11.21 21596
214 질의작성 모든 필드에 하나 이상 중복 값 찾기 정만영 2010.04.27 21584
213 응용개발 PHP에서 prepared statement 사용하기 3 Prototype 2009.04.16 21454
212 응용개발 CUBRID에서 CHAR와 NCHAR의 차이점 cubebridge 2010.07.01 21316
211 운영관리 큐브리드 백업파일(볼륨)을 이용한 과거 데이터 복구 시나리오 janus 2010.04.01 21250
210 질의작성 MERGE INTO 사용 예제 ( INSERT, UPDATE문을 1개의 쿼리로 실행 ) 권호일 2015.05.01 21230
209 질의작성 오류데이타검증 - 숫자 이외의 데이타 확인하는 방법 권호일 2013.01.17 21115
208 마이그레이션 오라클 to CUBRID로 마이그레이션 수행 시 주의사항 정만영 2012.03.02 21057
207 기타 테이블에 comment 사용하기 1 남재우 2010.01.01 21050
206 기타 csql에서 Java SP를 이용 조회 시 한글 깨짐현상 조치방법 cubebridge 2009.05.21 21044
205 응용개발 utf-8로 저장된 한글이 JAVA SP를 사용하여 읽어 오면 깨져 보일때 손승일 2012.03.10 20795
204 운영관리 CUBRID LOCK 관련 오류(ERROR CODE = -75) 정리 정만영 2009.12.01 20654
203 기타 전자정부 표준프레임워크 CUBRID 사용 방법 문의 참조 cubebridge 2012.09.17 20597
202 마이그레이션 오라클의 order by 시 first와 last 대체 사용법 file cubebridge 2012.11.12 20571
201 CUBRID 매니저 MS949 charset을 CM에서 선택할 수 없는 현상 조치방법 cubebridge 2010.05.17 20543
200 운영관리 막무가내 DBA의 DISK 장애 대처 정병주 2009.04.16 20444
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

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