MySQLi-ALTER 명령

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

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

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

mysql> use TUTORIALS;
Database changed

mysql> create table tutorials_alter
   -> (
   -> i INT,
   -> c CHAR(1)
   -> );
Query OK, 0 rows affected (0.27 sec)

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

열 삭제, 추가 또는 재배치

기존 열을 삭제한다고 가정합니다. i MySQLi 테이블 위에서 다음을 사용합니다. DROP 절과 함께 ALTER 다음과 같이 명령-

mysql> ALTER TABLE tutorials_alter  DROP i;

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

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

mysql> ALTER TABLE tutorials_alter ADD i INT;

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

mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c     | char(1) | YES  |     | NULL    |       |
| i     | int(11) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.01 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 절에서만 작동합니다. 즉, 테이블 내에서 기존 열의 위치를 ​​변경하려면 먼저 해당 열을 삭제 한 다음 새 위치에 추가해야합니다.

열 정의 또는 이름 변경

열 정의를 변경하려면 다음을 사용하십시오. MODIFY 또는 CHANGEALTER 명령과 함께 절. 예를 들어, 열을 변경하려면c CHAR (1)에서 CHAR (10)까지 다음을 수행하십시오.

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

CHANGE를 사용하면 구문이 약간 다릅니다. CHANGE 키워드 뒤에 변경할 열의 이름을 지정한 다음 새 이름을 포함하는 새 정의를 지정합니다. 다음 예제를 시도해보십시오.

mysql> ALTER TABLE tutorials_alter CHANGE i j BIGINT;

이제 CHANGE를 사용하여 열 이름을 변경하지 않고 j를 BIGINT에서 INT로 다시 변환하면 명령문이 예상대로됩니다.

mysql> ALTER TABLE tutorials_alter CHANGE j j INT;

널 및 기본값 속성에 대한 ALTER TABLE의 효과-

열을 수정하거나 변경할 때 열에 NULL 값을 포함 할 수 있는지 여부와 기본값을 지정할 수도 있습니다. 실제로 이렇게하지 않으면 MySQLi는 이러한 속성에 대한 값을 자동으로 할당합니다.

다음은 NOT NULL 열의 기본 값이 100 인 예입니다.

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

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

열의 기본값 변경

ALTER 명령을 사용하여 모든 열의 기본값을 변경할 수 있습니다. 다음 예제를 시도해보십시오.

mysql> ALTER TABLE tutorials_alter ALTER j SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c     | char(10)   | YES  |     | NULL    |       |
| j     | bigint(20) | NO   |     | 1000    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

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

mysql> ALTER TABLE tutorials_alter ALTER j DROP DEFAULT;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c     | char(10)   | YES  |     | NULL    |       |
| j     | bigint(20) | NO   |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

테이블 유형 변경

다음을 사용하여 테이블 유형을 사용할 수 있습니다. TYPE ALTER 명령과 함께 절.

현재 테이블 유형을 찾으려면 SHOW TABLE STATUS 문을 사용하십시오.

mysql>  SHOW TABLE STATUS LIKE 'tutorials_alter'\G
*************************** 1. row ***************************
           Name: tutorials_alter
         Engine: InnoDB
        Version: 10
     Row_format: Compact
           Rows: 0
 Avg_row_length: 0
    Data_length: 16384
Max_data_length: 0
   Index_length: 0
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2017-02-17 11:30:29
    Update_time: NULL
     Check_time: NULL
      Collation: latin1_swedish_ci
       Checksum: NULL
 Create_options:
        Comment:
1 row in set (0.00 sec)

테이블 이름 바꾸기

테이블의 이름을 바꾸려면 RENAMEALTER TABLE 문의 옵션입니다. 다음 예제를 사용하여 tutorials_alter의 이름을 tutorials_bks로 바꾸십시오.

mysql> ALTER TABLE tutorials_alter RENAME TO tutorials_bks;

ALTER 명령을 사용하여 MySQL 파일에 INDEX를 만들고 삭제할 수 있습니다. 이 기능은 다음 장에서 살펴 보겠습니다.