오라클 캐릭터셋 변경

2010.07.30 17:22

조인상 조회 수:13491

원문 : http://www.ischo.net -- 조인상 // 시스템 엔지니어

Writer : http://www.ischo.net -- ischo // System Engineer in Replubic Of Korea

+++++++++++++++++++++++++++++++++++++++++++++++++++++++

 

원문 : http://www.ischo.net -- 조인상 //시스템 엔지니어
출처 : http://database.sarang.net/?inc=read&aid=8187&criteria=oracle&subcrit=&id=&limit=20&keyword=ORA-12701&page=1


+++++++++++++++++++++++++++++++++++++++++++++++++++++++ 
 

데이타베이스의 CHARACTER SET은 데이타 딕셔너리 테이블인 sys.props$에

들어 있다

 

SQL>desc sys.props$

Name Null? Type

------------------------------- ----------------- ---------------

NAME NOT NULL VARCHAR2(30)

VALUE$ VARCHAR2(2000)

COMMENT$ VARCHAR2(2000)

 

SQL>column c1 format a30

SQL>select name c1, value$ c1 from sys.props$;

 

C1 C1

----------------------------- ------------------------------

DICT.BASE 2

NLS_LANGUAGE AMERICAN

NLS_TERRITORY AMERICA

NLS_CURRENCY $

NLS_ISO_CURRENCY AMERICA

NLS_NUMERIC_CHARACTERS .,

NLS_DATE_FORMAT DD-MON-YY

NLS_DATE_LANGUAGE AMERICAN

NLS_CHARACTERSET US7ASCII

NLS_SORT BINARY

GLOBAL_DB_NAME NLSV7.WORLD

 

여기서 NLS_CHARACTERSET에 현재 DB의 CHARACTER SET이 들어 있는데 이 값을

변경하여 DB의 CHARACTER SET을 변경할 수 있다. 여기서는 US7ASCII에서

KO16KSC5601 로 옮기는 경우를 알아보자.

 

우선 바꾸고자 하는 CHRACTER SET이 지원되는 지를 다음 명령으로 확인한다.

 

select convert('a','KO16KSC5601','US7ASCII') from dual;

 

만약 이 Select 문에서 ORA-01482 에러가 발생하면 지정한 CHARACTER SET이

지원되지 않는 경우이며 에러가 발생하지 않으면 CHARACTER SET을 변경할 수

있다.

 

작업을 하기전에는 만약을 위해서 DB 전체를 백업 받아두도록 한다.

CHARACTER SET 을 잘못 변경하면 DB 를 OPEN 할수가 없기 때문이다.

---------------------------------------------------------------

 

1. 다음의 Update문을 실행하여 CHARACTER SET을 변경한다.

 

UPDATE sys.props$

SET value$ = 'KO16KSC5601'

WHERE name = 'NLS_CHARACTERSET';

 

Update 시에 NLS_CHARACTERSET을 지원되지 않는 값으로 잘못 설정하거나

실수로 콘트롤 문자 같은 것이 들어가게 되면 DB가 Shutdown 된 다음에는

Startup 이 안 되므로 Update 후에 다음 명령으로 확인을 한 다음에 Commit을

하도록 한다.

 

select name, value$

from sys.props$

where value$ = 'KO16KSC5601';

 

Select가 제대로 출력되면 Commit 하고 Shutdown 했다가 Startup 하게 되면

새로운 CHARACTER SET 값을 갖게 된다. SELECT가 안 되면 ROLLBACK하고 UPDATE

부터 다시 하도록 한다.

 

2. 환경 변수 NLS_LANG 을 변경한다.

 

.profile ( or .cshrc) 에서

 

NLS_LANG=American_America.KO16KSC5601; export NLS_LANG

 

or

 

setenv NLS_LANG American_America.KO16KSC5601

번호 제목 글쓴이 날짜 조회 수
115 checkpoint not complete에 대해서 ischo 2013.05.22 255
114 백업에 관한 조언 조인상 2010.05.12 5184
113 [사이트 소개]오라클 사용자 그룹 조인상 2010.05.12 5707
112 [기타] 디비튜닝에 대한 질문과답변내용... 조인상 2010.05.12 5718
111 필수로 암기해야 할 view 들... 조인상 2010.05.12 5750
110 오라클 재시작시에 롤백세그먼트 OFFLINE 조인상 2010.05.12 5784
109 인텔 펜티엄4 기반 Windows에 설치시 오류에 대해서 조인상 2010.05.12 5795
108 오라클 뷰들... 조인상 2010.05.12 5908
107 OS의 파일사이즈가 2GB로 제한될때 split으로 나누기 조인상 2010.05.12 6189
106 패치 중 OS 문제로 runInstaller가 끊길때 조인상 2010.05.12 6429
105 OPATCH(V9.2) 기능 및 사용가이드 조인상 2010.05.12 6577
104 오라클 인덱스 분리해서 임포트 하는 방법 조인상 2010.05.12 6643
103 OPN 가입시의 장점 file 조인상 2010.05.12 6721
102 OS재설치 후 오라클 복구(솔라리스) 조인상 2010.05.12 6779
101 테이블 복구 사례 조인상 2010.05.12 6816
100 오라클 8.1.7 -> 7.3.4 로 DB data 이전 조인상 2010.05.12 6923
99 INCREMENTAL, CUMULATIVE, COMPLETE EXPORT & IMPORT 조인상 2010.05.12 7144
98 오라클에 접속하는 최대 인스턴스개수(세션개수)를 늘리는 방법 조인상 2010.05.12 7149
97 AIX5.2 + 9.2.0.1.0 install + 9.2.0.5.0 patch 조인상 2010.05.12 7287
96 Linux 32bit ( EntePrise AS 3.0) - 오라클 9.2.0.4 설치 조인상 2010.05.12 7326
서버에 요청 중입니다. 잠시만 기다려 주십시오...