> 데이터 베이스 > MySQL 튜토리얼 > mysql 테이블의 필드를 수정하는 방법은 무엇입니까?

mysql 테이블의 필드를 수정하는 방법은 무엇입니까?

青灯夜游
풀어 주다: 2020-10-13 16:39:04
원래의
18029명이 탐색했습니다.

mysql 테이블에서는 "ALTER TABLE 테이블 이름 CHANGE 이전 필드 이름 새 필드 이름 데이터 유형" 문을 사용하여 "ALTER TABLE 테이블 이름 MODIFY 필드 이름 새 데이터 유형"을 사용할 수 있습니다. 필드 데이터 유형을 수정합니다.

mysql 테이블의 필드를 수정하는 방법은 무엇입니까?

(권장 튜토리얼: mysql 비디오 튜토리얼)

필드 이름 수정

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

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

그 중:

  • 이전 필드 이름: 수정 전 필드 이름을 참조합니다.

  • 새 필드 이름: 수정된 필드 이름을 참조합니다.

  • 데이터 유형: 수정이 필요하지 않은 경우. 필드의 데이터 유형에 따라 데이터 유형을 변경할 수 있습니다. 이전과 동일하게 설정하되, 데이터 유형을 비워둘 수는 없습니다.

예제 1

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 表名 MODIFY 字段名 新数据类型;
로그인 후 복사

그 중:

  • 테이블 이름: 데이터 유형을 수정할 필드가 있는 테이블의 이름을 나타냅니다.

    필드 이름: 수정해야 하는 필드를 나타냅니다.
  • 새 데이터 유형: 수정된 필드의 새 데이터 유형을 나타냅니다.
  • 예제2

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)으로 수정된 것을 확인하였고, 수정에 성공하였습니다.

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

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