오라클 캐릭터셋 변경

2010.07.30 17:22

조인상 조회 수:13488

원문 : 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

서버에 요청 중입니다. 잠시만 기다려 주십시오...