====== MySQL 테이블 수정 ====== * [[https://www.percona.com/doc/percona-toolkit/LATEST/pt-online-schema-change.html|pt-online-schema-change]] Lock 덜걸리고 Alter Table 수행하기 위한 솔루션 ===== 이름 바꾸기 ===== 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_CHECKS**을 ''0''으로 지정해야한다. 안 그러면 ''Cannot truncate a table referenced in a foreign key constraint'' 오류가 발생한다.