MySQL-ALTER 명령

MySQL ALTER 명령은 테이블, 테이블 필드의 이름을 변경하거나 테이블의 기존 열을 추가 또는 삭제하려는 경우 매우 유용합니다.

테이블 생성부터 시작하겠습니다. testalter_tbl.

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> create table testalter_tbl
   -> (
   -> i INT,
   -> c CHAR(1)
   -> );
Query OK, 0 rows affected (0.05 sec)
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   i   | int(11) | YES  |     |   NULL  |       |
|   c   | char(1) | YES  |     |   NULL  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

열 삭제, 추가 또는 재배치

위의 MySQL 테이블에서 기존 열 i를 삭제하려면 다음을 사용합니다. DROP 절과 함께 ALTER 아래와 같이 명령-

mysql> ALTER TABLE testalter_tbl  DROP i;

DROP 열이 테이블에 남아있는 유일한 경우 절이 작동하지 않습니다.

열을 추가하려면 ADD를 사용하고 열 정의를 지정하십시오. 다음 문은i testalter_tbl에 열-

mysql> ALTER TABLE testalter_tbl ADD i INT;

이 명령문을 발행 한 후 testalter는 테이블을 처음 만들 때와 동일한 두 개의 열을 포함하지만 동일한 구조를 갖지 않습니다. 기본적으로 테이블 끝에 추가되는 새 열이 있기 때문입니다. 그래서 비록i 원래 mytbl의 첫 번째 열 이었지만 이제는 마지막 열입니다.

mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   c   | char(1) | YES  |     |   NULL  |       |
|   i   | int(11) | YES  |     |   NULL  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

테이블 내의 특정 위치에 열을 원한다는 것을 나타내려면 FIRST를 사용하여 첫 번째 열로 만들거나 AFTER col_name 새 열이 col_name 뒤에 위치해야 함을 나타냅니다.

다음을 시도하십시오 ALTER TABLE 문, 사용 SHOW COLUMNS 각각의 효과를 확인하려면

ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT FIRST;
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT AFTER c;

FIRST 및 AFTER 지정자는 ADD 절에서만 작동합니다. 즉, 테이블 내에서 기존 열의 위치를 ​​변경하려면 먼저DROP 그 다음 ADD 새로운 위치에 있습니다.

열 정의 또는 이름 변경 (변경)

열 정의를 변경하려면 다음을 사용하십시오. MODIFY 또는 CHANGE ALTER 명령과 함께 절.

예를 들어, 열을 변경하려면 c CHAR (1)에서 CHAR (10)까지 다음 명령을 사용할 수 있습니다.

mysql> ALTER TABLE testalter_tbl MODIFY c CHAR(10);

CHANGE, 구문이 약간 다릅니다. CHANGE 키워드 뒤에 변경할 열의 이름을 지정한 다음 새 이름을 포함하는 새 정의를 지정합니다.

다음 예제를 시도하십시오-

mysql> ALTER TABLE testalter_tbl CHANGE i j BIGINT;

이제 CHANGE를 사용하여 변환하는 경우 j ...에서 BIGINT 돌아가다 INT 열 이름을 변경하지 않고 다음과 같은 명령문이됩니다.

mysql> ALTER TABLE testalter_tbl CHANGE j j INT;

The Effect of ALTER TABLE on Null and Default Value Attributes− 열을 수정하거나 변경할 때 열에 NULL 값을 포함 할 수 있는지 여부와 기본값을 지정할 수도 있습니다. 실제로 이렇게하지 않으면 MySQL은 이러한 속성에 대한 값을 자동으로 할당합니다.

다음 코드 블록은 예입니다. NOT NULL 열의 기본 값은 100입니다.

mysql> ALTER TABLE testalter_tbl 
   -> MODIFY j BIGINT NOT NULL DEFAULT 100;

위의 명령을 사용하지 않으면 MySQL은 모든 열에서 NULL 값을 채 웁니다.

열의 기본값 변경 (변경)

다음을 사용하여 모든 열의 기본값을 변경할 수 있습니다. ALTER 명령.

다음 예제를 시도해보십시오.

mysql> ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   c   | char(1) | YES  |     |   NULL  |       |
|   i   | int(11) | YES  |     |   1000  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

DROP 절을 사용하여 모든 열에서 기본 제약 조건을 제거 할 수 있습니다. ALTER 명령.

mysql> ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   c   | char(1) | YES  |     |   NULL  |       |
|   i   | int(11) | YES  |     |   NULL  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

테이블 유형 변경 (변경)

다음을 사용하여 테이블 유형을 사용할 수 있습니다. TYPEALTER 명령과 함께 절. 다음 예제를 사용하여testalter_tbl ...에 MYISAM 테이블 유형.

현재 테이블 유형을 찾으려면 SHOW TABLE STATUS 성명서.

mysql> ALTER TABLE testalter_tbl TYPE = MYISAM;
mysql>  SHOW TABLE STATUS LIKE 'testalter_tbl'\G
*************************** 1. row ****************
           Name: testalter_tbl
           Type: MyISAM
     Row_format: Fixed
           Rows: 0
 Avg_row_length: 0
    Data_length: 0
Max_data_length: 25769803775
   Index_length: 1024
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2007-06-03 08:04:36
    Update_time: 2007-06-03 08:04:36
     Check_time: NULL
 Create_options:
        Comment:
1 row in set (0.00 sec)

테이블 이름 바꾸기 (변경)

테이블의 이름을 바꾸려면 RENAME 의 옵션 ALTER TABLE 성명서.

이름을 바꾸려면 다음 예제를 시도하십시오. testalter_tbl ...에 alter_tbl.

mysql> ALTER TABLE testalter_tbl RENAME TO alter_tbl;

ALTER 명령을 사용하여 MySQL 파일에 INDEX 명령을 만들고 삭제할 수 있습니다. 다음 장에서이 명령에 대해 자세히 설명합니다.