Background Image
조회 수 12409 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
데이터베이스를 운영 중 사용하던 칼럼의 data type을 변경해야하는 경우가 생길 수 있다.(변경을 권장하지 않는다.) 이러한 경우 CUBRID에서의 해당 칼럼 data type변경 방안과 각각에 대한 설명을 하도록 한다.

첫번째 변경 방법은 아래와 같다.
변경할 칼럼 이름 바꾸기 --> 원래 이름의 칼럼을 변경할 타입으로 추가 --> 데이터를 복제 --> 원본 칼럼을 삭제
사용예)
=== <Help: Schema of a Class> ===

<Class Name> 

dumy

<Attributes> 
...
exam character varying(300)

csql> alter table dumy rename exam as temp
csql> ;x

Current transaction has been committed.

1 command(s) successfully processed.

csql> alter table dumy add attribute exam string
csql> ;x

Current transaction has been committed.

1 command(s) successfully processed.

csql> update dumy set exam=cast(temp as string)
csql> ;x

23 rows updated.

Current transaction has been committed.

1 command(s) successfully processed.

csql> alter table dumy drop attribute temp
csql> ;x

Current transaction has been committed.

1 command(s) successfully processed.

csql> ;sc dumy

=== <Help: Schema of a Class> ===

<Class Name> 

dumy

<Attributes> 
...
exam string

Current transaction has been committed.
위의 경우 주의할 사항이 아래와 같다.
1. 프로그램 개발 시 각 칼럼을 명시적으로 표시되어 있어야 한다.
 - 위의 방법은 칼럼을 추가하고 삭제하므로 칼럼의 위치가 변경되므로 insert문 등에 각 칼럼이 명시적이지 않다면 순서의 오류로 인해 정상적인 작업이 진행되지 않을 것이다.
2. 칼럼을 추가 및 데이터 update방식이므로 to_char, to_number를 이용하여 데이터 복제가 가능하며, 경우에 따라 char --> int, int --> char 간의 이전이 가능하다. 단, 해당 데이터가 변경이 가능한 데이터로 입력되어 있어야 한다.

두번째 변경방법은 아래와 같다.
1. 원하는 테이블을 변경하고자 하는 칼럼만 변경하여 다른 이름으로 생성한다.
2. 원본 테이블의 데이터를 생성한 테이블로 이전한다.
3. 원본 테이블의 이름을 변경하고 생성한 테이블을 원본 테이블 이름으로 변경한다.
사용예)
=== <Help: Schema of a Class> ===

<Class Name> 

dumy

<Attributes> 
...
exam  character varying(300)

csql> create table dumy_new ...
csql> ;x
csql> insert into dumy_new select * from dumy
csql> ;x
csql> rename class dumy as dumy_bak;
csql> rename class dumy_new as dumy;
csql> ;x
=== <Help: Schema of a Class> ===

<Class Name> 

dumy

<Attributes> 
...
exam  string
위와 같이 수행할 경우 순서의 변화 없이 그대로 사용할 수 있다는 장점이 있다.
단, 테이블의 데이터가 많을 경우 전체를 읽어 insert하는 작업에 의해 서비스에 부하를 줄 수 있으며, 데이터 량에 따라 불필요한 공간의 사용 등의 문제가 발생할 수 있다.(dumy_new테이블은 서비스 테이블이 아니기에 서비스에 영향을 주지는 않는다.)

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
279 운영관리 csql 데이터 입력방법 정만영 2009.06.09 213343
278 마이그레이션 CUBRID vs MySQL vs ORACLE SQL 타입별 비교 정만영 2013.07.12 69164
277 응용개발 weblogic 8.1 에 CUBRID Connection Pool, DataSource 설정 방법 file 웁쓰 2009.07.01 66306
276 응용개발 WHERE 조건에서 다중 컬럼 IN절 처리 최적화 방법 (cubrid + ibatis) 1 이상신 2015.08.21 55140
275 응용개발 Weblogic 10.0 사용시 JDK 1.5를 사용한 JDBC 드라이버 사용시 주의사항. cubebridge 2012.02.22 51957
274 마이그레이션 타 DBMS를 CUBRID로 마이그레이션 시 varchar,char 컬럼 사이즈 관련 손승일 2010.07.01 38025
273 질의작성 데이터 존재하면 update, 존재하지 않으면 insert 방법(ON DUPLICATE KEY UPDATE) 손승일 2010.08.11 38002
272 질의작성 예약어를 테이블명이나 컬럼명으로 사용시 admin 2008.11.21 37436
271 응용개발 JDBC 사용시 SQL 로깅 - p6spy 사용 1 웁쓰 2009.07.01 36002
270 기타 좀비 프로세스 일괄 삭제하기 janus 2009.12.12 35407
269 응용개발 CUBRID AUTO_INCREMENT 컬럼 MySQL LAST_INSERT_ID() 대체 방법 손승일 2009.12.22 33235
268 운영관리 CUBRID에서의 BLOB/CLOB 사용시 백업 및 복구에 대한 주의 점 cubebridge 2012.09.18 33157
267 마이그레이션 MySQL의 limit 명령어 처리 1 admin 2008.11.21 32686
266 CUBRID 매니저 Java SP사용시 JNI_CreateJavaVM 에러메시지 해결 방법 file seongjoon 2009.07.15 32043
265 응용개발 php에서 serialize/unserialize 사용 시 주의할 점 시난 2009.12.29 31629
264 운영관리 CUBRID 사용시 방화벽 설정 3 admin 2008.11.21 30998
263 마이그레이션 CUBRID 하위버젼에서 CUBRID2008로의 업그레이드 방법 1 남재우 2008.12.06 30154
262 운영관리 큐브리드 사용포트 정리 3 정만영 2009.06.19 29778
261 질의작성 CUBRID DB 내의 auto_increment 값을 초기화 하자. 손승일 2009.10.28 29733
260 응용개발 CUBRID와 Oracle에서의 ''(공백)의 차이 비교 cubebridge 2010.10.01 28584
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