> 데이터 베이스 > MySQL 튜토리얼 > mysql이 테이블 구조를 수정하는 데 사용하는 명령문은 무엇입니까?

mysql이 테이블 구조를 수정하는 데 사용하는 명령문은 무엇입니까?

青灯夜游
풀어 주다: 2022-01-24 17:30:33
원래의
14026명이 탐색했습니다.

MySQL의 테이블 구조 수정 문은 "ALTER TABLE"입니다. 이 문은 열 추가 또는 삭제, 원래 열 유형 변경, 열 또는 테이블 이름 바꾸기 등 원본 테이블의 구조를 변경할 수 있습니다. "ALTER TABLE" <테이블 이름> [옵션 수정]".

mysql이 테이블 구조를 수정하는 데 사용하는 명령문은 무엇입니까?

이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터.

mysql에서 테이블 구조를 수정하는 명령문은 "ALTER TABLE"입니다.

ALTER TABLE 문은 열 추가 또는 삭제, 인덱스 생성 또는 취소, 원래 열 유형 변경, 열 또는 테이블 이름 바꾸기 등 원본 테이블의 구조를 변경할 수 있습니다.

MySQL은 ALTER TABLE 문을 사용하여 테이블을 수정합니다. 테이블을 수정하기 위해 일반적으로 사용되는 작업에는 테이블 이름 수정, 필드 데이터 유형 또는 필드 이름 수정, 필드 추가 및 삭제, 필드 배열 수정, 테이블의 스토리지 엔진 변경, 테이블의 외래 키 제약 조건 삭제 등이 포함됩니다.

일반적으로 사용되는 구문 형식은 다음과 같습니다.

ALTER TABLE <表名> [修改选项]
로그인 후 복사

옵션 수정을 위한 구문 형식은 다음과 같습니다.

{ ADD COLUMN <列名> <类型>
| CHANGE COLUMN <旧列名> <新列名> <新列类型>
| ALTER COLUMN <列名> { SET DEFAULT <默认值> | DROP DEFAULT }
| MODIFY COLUMN <列名> <类型>
| DROP COLUMN <列名>
| RENAME TO <新表名>
| CHARACTER SET <字符集名>
| COLLATE <校对规则名> }
로그인 후 복사

필드 추가

비즈니스 변화에 따라 기존 테이블에 새 필드를 추가해야 할 수도 있습니다. , a 완전한 필드에는 필드 이름, 데이터 유형 및 무결성 제약 조건이 포함됩니다. 필드 추가의 구문 형식은 다음과 같습니다.

ALTER TABLE <表名> ADD <新字段名> <数据类型> [约束条件] [FIRST|AFTER 已存在的字段名];
로그인 후 복사

새 필드 이름은 추가해야 하는 필드의 이름입니다. FIRST는 선택적 매개변수이며, 해당 기능은 새로 추가된 필드를 첫 번째 필드로 설정하는 것입니다. 테이블 AFTER는 선택적 매개변수이며, 해당 기능은 지정된 기존 필드 이름 끝에 새로 추가된 필드를 추가하는 것입니다.

【예제 1】ALTER TABLE을 사용하여 tb_emp1 테이블의 구조를 수정하고 테이블의 첫 번째 열에 int 유형 필드 col1을 추가합니다. 입력 SQL 문과 실행 결과는 다음과 같습니다.

mysql> ALTER TABLE tb_emp1
    -> ADD COLUMN col1 INT FIRST;
Query OK, 0 rows affected (0.94 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> DESC tb_emp1;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| col1   | int(11)     | YES  |     | NULL    |       |
| id     | int(11)     | YES  |     | NULL    |       |
| name   | varchar(25) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float       | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)
로그인 후 복사

팁: "FIRST 또는 AFTER 기존 필드 이름"은 테이블에서 새 필드의 위치를 ​​지정하는 데 사용됩니다. SQL 문에 이 두 매개 변수가 없으면 새로 추가된 필드가 테이블의 끝으로 설정됩니다. 기본적으로 데이터 테이블.

【예제 2】ALTER TABLE을 사용하여 테이블 tb_emp1의 구조를 수정하고 name 열 뒤에 int 유형 필드 col2를 추가합니다. 입력 SQL 문과 실행 결과는 다음과 같습니다.

mysql> ALTER TABLE tb_emp1
    -> ADD COLUMN col2 INT AFTER name;
Query OK, 0 rows affected (0.50 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> DESC tb_emp1;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| col1   | int(11)     | YES  |     | NULL    |       |
| id     | int(11)     | YES  |     | NULL    |       |
| name   | varchar(25) | YES  |     | NULL    |       |
| col2   | int(11)     | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float        | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)
로그인 후 복사

tb_emp1 테이블에 col2라는 필드가 추가된 것을 볼 수 있습니다. 해당 필드의 위치는 지정된 이름 필드 뒤에 있습니다.

필드의 데이터 유형 수정

필드의 데이터 유형을 수정하는 것은 필드의 데이터 유형을 다른 데이터 유형으로 변환하는 것입니다. MySQL에서 필드 데이터 유형을 수정하는 구문 규칙은 다음과 같습니다.

ALTER TABLE <表名> MODIFY <字段名> <数据类型>
로그인 후 복사

그 중 테이블 이름은 데이터 유형을 수정해야 하는 필드가 있는 테이블의 이름을 나타내고, 필드 이름은 해당 필드를 나타냅니다. 수정해야 하며 데이터 유형은 수정된 필드의 새 데이터 유형을 나타냅니다.

【예제 3】ALTER TABLE을 사용하여 tb_emp1 테이블의 구조를 수정하고, name 필드의 데이터 유형을 VARCHAR(22)에서 VARCHAR(30)으로 변경하면 입력 SQL 문과 실행 결과는 다음과 같습니다.

mysql> ALTER TABLE tb_emp1
    -> MODIFY name VARCHAR(30);
Query OK, 0 rows affected (0.15 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> DESC tb_emp1;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| col1   | int(11)     | YES  |     | NULL    |       |
| id     | int(11)     | YES  |     | NULL    |       |
| name   | varchar(30) | YES  |     | NULL    |       |
| col2   | int(11)     | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float        | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)
로그인 후 복사

Statement 실행 후, tb_emp1 테이블의 name 필드의 데이터 타입이 VARCHAR(30)으로 수정된 것을 확인하였고, 수정에 성공하였습니다.

필드 삭제

필드 삭제는 데이터 테이블의 필드를 테이블에서 제거하는 것입니다. 구문은 다음과 같습니다.

ALTER TABLE <表名> DROP <字段名>;
로그인 후 복사

이 중에서 필드 이름은 해당 필드의 이름을 나타냅니다. 테이블에서 삭제해야 합니다.

【예제 4】ALTER TABLE을 사용하여 tb_emp1 테이블의 구조를 수정하고 col2 필드를 삭제하면 입력 SQL 문과 실행 결과는 다음과 같습니다.

mysql> ALTER TABLE tb_emp1
    -> DROP col2;
Query OK, 0 rows affected (0.53 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> DESC tb_emp1;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| col1   | int(11)     | YES  |     | NULL    |       |
| id     | int(11)     | YES  |     | NULL    |       |
| name   | varchar(30) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float        | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)
로그인 후 복사

필드 이름 수정

MySQL에서 테이블 필드 이름을 수정하는 구문 규칙은 다음과 같습니다.

ALTER TABLE <表名> CHANGE <旧字段名> <新字段名> <新数据类型>;
로그인 후 복사

이 중 이전 필드 이름은 수정 전의 필드 이름을 참조합니다. 수정된 필드 이름은 수정된 데이터 유형을 나타냅니다. 필드의 데이터 유형을 수정할 필요가 없으면 새 데이터 유형을 원래 데이터 유형과 동일하게 설정할 수 있습니다. 비어있어.

【예제 5】ALTER TABLE을 사용하여 tb_emp1 테이블의 구조를 수정하고, col1 필드 이름을 col3으로 변경하고, 데이터 유형을 CHAR(30)으로 변경하면 입력 SQL 문과 실행 결과는 다음과 같습니다.

mysql> ALTER TABLE tb_emp1
    -> CHANGE col1 col3 CHAR(30);
Query OK, 0 rows affected (0.76 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> DESC tb_emp1;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| col3   | char(30)    | YES  |     | NULL    |       |
| id     | int(11)     | YES  |     | NULL    |       |
| name   | varchar(30) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float        | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
5 rows in set (0.01 sec)
로그인 후 복사

CHANGE는 MODIFY와 동일한 효과를 얻기 위해 데이터 유형만 수정할 수도 있습니다. 이 방법은 SQL 문의 "새 필드 이름"과 "이전 필드 이름"을 동일한 이름으로 설정하고 "데이터"만 변경하는 것입니다. 유형".

팁: 기계에서는 다양한 유형의 데이터가 다양한 방식과 길이로 저장되므로 데이터 유형을 수정하면 데이터 테이블의 기존 데이터 기록에 영향을 미칠 수 있습니다. 따라서 데이터 테이블에 이미 데이터가 있는 경우 수정하지 마세요. 쉽게 데이터 유형입니다.

테이블 이름 수정

MySQL은 ALTER TABLE 문을 사용하여 테이블 이름을 수정합니다. 구문 규칙은 다음과 같습니다.

ALTER TABLE <旧表名> RENAME [TO] <新表名>;
로그인 후 복사

그 중 TO는 선택적 매개 변수이며 사용 여부를 나타냅니다. 결과에 영향을 미치지 않습니다.

【예제 6】ALTER TABLE을 사용하여 데이터 테이블 tb_emp1의 이름을 tb_emp2로 변경합니다. 입력 SQL 문과 실행 결과는 다음과 같습니다.

mysql> ALTER TABLE tb_emp1
    -> RENAME TO tb_emp2;
mysql> SHOW TABLES;
+--------------------+
| Tables_in_test_db  |
+--------------------+
| tb_emp2            |
+--------------------+
1 rows in set (0.00 sec)
로그인 후 복사

提示:用户可以在修改表名称时使用 DESC 命令查看修改后两个表的结构,修改表名并不修改表的结构,因此修改名称后的表和修改名称前的表的结构是相同的。

【相关推荐:mysql视频教程

위 내용은 mysql이 테이블 구조를 수정하는 데 사용하는 명령문은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿