사용자 도구

사이트 도구


database:mysql:alter_table

MySQL 테이블 수정

이름 바꾸기

ALTER TABLE tablename RENAME bbs;

컬럼 속성 수정

ALTER TABLE tablename MODIFY colname INT NOT NULL AUTO_INCREMENT PRIMARY KEY;

ALTER TABLE tablename MODIFY 컬럼이름 컬럼속성

컬럼 이름 바꾸기

ALTER TABLE tablename CHANGE colname newcolname INT NOT NULL AUTO_INCREMENT;

CHANGE는 컬럼 속성뿐아니라 이름도 바꿔준다.

컬럼 추가

ALTER TABLE bbs ADD name VARCHAR(10);

ALTER TABLE tablename ADD 컬럼이름 컬럼속성

컬럼 삭제

ALTER TABLE bbs DROP colname;

특정 컬럼 뒤에 새로운 컬럼 추가

ALTER TABLE bbs ADD newcol VARCHAR(10) AFTER num;

num 컬럼 뒤에 newcol 컬럼 추가.

기존 컬럼을 지우고 맨 앞에 컬럼 추가

ALTER TABLE bbs DROP newcol, ADD newcol VARCHAR(10) FIRST;

맨 앞에 추가하려면 FIRST를 사용한다.

PRIMARY KEY 속성 삭제

ALTER TABLE test DROP PRIMARY KEY;

이미 PRIMARY KEY인 컬럼의 속성을 바꿀 때

PRIMARY KEY 속성은 지정하지 말고, NOT NULL 속성을 함께 지정해 주면 기존 PRIMARY KEY 속성은 그대로 남은 상태로 컬럼의 속성을 변경할 수 있다.

ALTER TABLE test MODIFY a CHAR(1) NOT NULL;

테이블의 내용 전체 삭제

SET FOREIGN_KEY_CHECKS = 0;
TRUNCATE TABLE tablename;
SET FOREIGN_KEY_CHECKS = 1;

트랜잭션에 의해 복구될 수 없다.

MySQL 5.5.7 부터 FOREIGN KEY 설정이 된 테이블을 TRUNCATE 하려면 FOREIGN_KEY_CHECKS0으로 지정해야한다. 안 그러면 Cannot truncate a table referenced in a foreign key constraint 오류가 발생한다.

database/mysql/alter_table.txt · 마지막으로 수정됨: 2018/02/28 16:03 저자 kwon37xi