Jini's Blog

Ing...

  • Home
  • Business
    • Internet
    • Market
    • Stock
  • Parent Category
    • Child Category 1
      • Sub Child Category 1
      • Sub Child Category 2
      • Sub Child Category 3
    • Child Category 2
    • Child Category 3
    • Child Category 4
  • Featured
  • Health
    • Childcare
    • Doctors
  • Home
  • Business
    • Internet
    • Market
    • Stock
  • Downloads
    • Dvd
    • Games
    • Software
      • Office
  • Parent Category
    • Child Category 1
      • Sub Child Category 1
      • Sub Child Category 2
      • Sub Child Category 3
    • Child Category 2
    • Child Category 3
    • Child Category 4
  • Featured
  • Health
    • Childcare
    • Doctors
  • Uncategorized

Row 단위 데이터를 Column 단위로 변환

 Jini     오전 2:34     Oracle     No comments   

■ 기본원리

1. 각 ROW 데이터가 몇 번째 행의 몇 번째 컬럼에 위치해야 하는지를 결정
2. 예를 들어서 아래와 같은 데이터가 있으며 한 행에 4개의 컬럼으로 표시하고 싶다고 할 경우 각 위치는 다음과 같다.

  [원본자료]
  EMP_ID
   ----
   A001 -> 1, 1
   B001 -> 1, 2
   C001 -> 1, 3
   D001 -> 1, 4
   E001 -> 2, 1
   F001 -> 2, 2
   G001 -> 2, 3
   H001 -> 2, 4
   I001 -> 3, 1
   J001 -> 3, 2
   K001 -> 3, 3
   L001 -> 3, 4

3. 위치를 결정했으면 해당 위치 값을 ROWNUM과 CEIL, MOD를 통해서 만든다.
SELECT NO
     , CEIL(NO/4) AS ROWINDEX
     , MOD(NO, 4) AS COLINDEX
     , EMP_ID
FROM ( SELECT ROWNUM AS NO
                   , EMP_ID
        FROM    TEMP )
▶결과는 다음과 같다(COLINDEX값이 0인 경우를 좌표에서는 4번째 위치라고 생각)
NO    ROWINDEX    COLINDEX    EMP_ID
 1           1           1      A001
 2           1           2      B001
 3           1           3      C001
 4           1           0      D001
 5           2           1      E001
 [중략]
12           3           0      L001

4. 다음으로 각 행의 데이터를 DECODE 함수를 이용하여 좌표에 맞게 위치시킨다.
SELECT CEIL(NO/4) AS ROWINDEX
    ,  DECODE(MOD(NO, 4), 1, EMP_ID) AS COL1
    ,  DECODE(MOD(NO, 4), 2, EMP_ID) AS COL2
    ,  DECODE(MOD(NO, 4), 3, EMP_ID) AS COL3
    ,  DECODE(MOD(NO, 4), 0, EMP_ID) AS COL4
FROM ( SELECT ROWNUM AS NO
            , EMP_ID
       FROM    TEMP )
▶결과는 다음과 같다.
ROWINDEX  COL1    COL2    COL3    COL4
1         A001   
1                 B001  
1                         C001 
1                                 D001
2         E001   
2                 F001  
2                         G001 
2                                 H001
[중략]

5. 마지막으로 위 결과를 ROWINDEX 기준으로 GROUPING 해준다.
SELECT CEIL(NO/4) AS ROWINDEX
    ,  MAX(DECODE(MOD(NO, 4), 1, EMP_ID)) AS COL1
    ,  MAX(DECODE(MOD(NO, 4), 2, EMP_ID)) AS COL2
    ,  MAX(DECODE(MOD(NO, 4), 3, EMP_ID)) AS COL3
    ,  MAX(DECODE(MOD(NO, 4), 0, EMP_ID)) AS COL4
FROM ( SELECT ROWNUM AS NO
            , EMP_ID
        FROM    TEMP )            
GROUP BY CEIL(NO/4)

결과는 생략.
Read More
  • Share This:  
  •  Facebook
  •  Twitter
  •  Google+
  •  Stumble
  •  Digg

오라클 한글깨짐 현상해결

 Jini     오전 1:37     Oracle     No comments   

1. 레지스트리 편집기 실행 : 시작 -> 실행 -> regedit
2. HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE 하위 경로 폴더중 이름이 "NLS_LANG"인 속성의 데이터 확인
3. "NLS_LANG" 속성을 KOREAN_KOREA.KO16MSWIN949로 변경
4. CMD창에서 SQLPLUS /NOLOG 실행
5. CONN /AS SYSDBA 실행
6. 다음의 쿼리 수행
UPDATE PROPS$ SET VALUE$ ='KO16MSWIN949' WHERE NAME = 'NLS_CHARACTERSET';
UPDATE PROPS$ SET VALUE$ = 'AMERICAN_AMERICA.KO16MSWIN949' WHERE NAME = 'NLS_LANGUAGE';
COMMIT;

SHUTDOWN IMMEDIATE;
STARTUP;

※ 기존에 존재하던 한글 데이터는 깨질 수 있음.
※ 한글깨짐 현상은 위 방법외에 다른 방법도 존재하므로 위 방법으로 해결안될 경우 다른 방식으로 해결 필요.
Read More
  • Share This:  
  •  Facebook
  •  Twitter
  •  Google+
  •  Stumble
  •  Digg

한글이 3byte인 경우 캐릭터셋 확인

 Jini     오전 1:20     Oracle     No comments   

오라클의 문자집합이 KO16KSC5601, KO16MSWIN949 인 경우는 2 Byte로 한글을 인식.
UTF8/AL32UTF8의 경우 3Byte로 한글을 인식.
단 UTF8/AL32UTF8의 경우는 한글 정렬이 가능하다는 장점이 있다.

캐릭터셋 확인하는 방법
SELECT * FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER = 'NLS_CHARACTERSET';
Read More
  • Share This:  
  •  Facebook
  •  Twitter
  •  Google+
  •  Stumble
  •  Digg
최근 게시물 이전 게시물 홈

Popular Posts

  • 한글이 3byte인 경우 캐릭터셋 확인
    오라클의 문자집합이 KO16KSC5601, KO16MSWIN949 인 경우는 2 Byte로 한글을 인식. UTF8/AL32UTF8의 경우 3Byte로 한글을 인식. 단 UTF8/AL32UTF8의 경우는 한글 정렬이 가능하다는 장점이 있다. 캐릭...
  • 문법에서 문장까지(대명사)
    1. 대명사 ■ 인칭대명사 1) 대명사는 숙어 동사(phrasal verb) 사이에 쓴다. * I cut up half of one large banana and put it in cereal. 2) 소유격 대명사와 관사는 같이 쓸 수 ...
  • Redmine Text Format
    1. 글자색상 변경 %{color:red}dev% 2. 음영색상 변경 %{background:lightgreen} lightgreen% 3. 문단 넘버링(띄어쓰기 주의) # 큰 제목 ## 큰제목의 하위 제목 # 두번째 큰 제목 # ...
  • 오라클 한글깨짐 현상해결
    1. 레지스트리 편집기 실행 : 시작 -> 실행 -> regedit 2. HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE 하위 경로 폴더중 이름이 "NLS_LANG"인 속성의 데이터 확인 3. "...
  • Visual Studio 2013 팁 및 단축키(이클립스랑 비교)
    이클립스에는 있는데 VS에는 없어서 있었으면 하는 기능 중 실제로 있었는데 내가 몰랐던 것들 1. 한 줄 삭제 이클립스는 ctrl + d / VS는 ctrl + shift + l 2. 한 줄 그대로 복사하여 아래로 붙여넣기(위로 붙여넣기는 모...

Recent Posts

Recent Posts Widget

Blog Archive

  • ►  2023 (4)
    • ►  3월 (1)
    • ►  2월 (1)
    • ►  1월 (2)
  • ►  2022 (1)
    • ►  2월 (1)
  • ►  2020 (8)
    • ►  7월 (1)
    • ►  4월 (3)
    • ►  3월 (4)
  • ►  2018 (1)
    • ►  7월 (1)
  • ►  2015 (1)
    • ►  5월 (1)
  • ►  2014 (5)
    • ►  8월 (1)
    • ►  7월 (1)
    • ►  6월 (1)
    • ►  5월 (1)
    • ►  1월 (1)
  • ▼  2013 (10)
    • ►  12월 (1)
    • ►  11월 (1)
    • ►  9월 (2)
    • ▼  8월 (3)
      • Row 단위 데이터를 Column 단위로 변환
      • 오라클 한글깨짐 현상해결
      • 한글이 3byte인 경우 캐릭터셋 확인
    • ►  7월 (3)
  • ►  2012 (1)
    • ►  3월 (1)

Categories

  • 객체지향 (1)
  • 도서요약 (1)
  • 문법에서 문장까지 (2)
  • 일상 (1)
  • 자기계발 (1)
  • 책 (1)
  • 키보드 (1)
  • 키크론 (1)
  • blogspot (2)
  • error (1)
  • exception (1)
  • GIT (1)
  • JAVA (6)
  • JUNIT (1)
  • K8 PRO RGB (1)
  • kafka (1)
  • markdown (1)
  • mongodb (2)
  • mongotemplate (1)
  • optional (1)
  • Oracle (4)
  • Redmine (1)
  • spring (1)
  • stackedit (1)
  • troubleshooting (1)
  • Visual Studio (1)
  • Webflux (1)

Unordered List

Pages

  • 홈

Text Widget

Categories

Tags

Facebook

  • Home
  • Features
  • _Multi DropDown
  • __DropDown 1
  • __DropDown 2
  • __DropDown 3
  • _ShortCodes
  • _SiteMap
  • _Error Page
  • Documentation
  • Video Documentation
  • Download This Template

Footer Menu Widget

  • Home
  • About
  • Contact Us

Social Plugin

JINI. Powered by Blogger.

Copyright © Jini's Blog | Powered by Blogger
Design by Hardeep Asrani | Blogger Theme by NewBloggerThemes.com | Distributed By Gooyaabi Templates