mysql怎麼增加列(字段)

青灯夜游
發布: 2021-12-03 18:21:09
原創
52392 人瀏覽過

在mysql中,可以使用「ALTER TABLE」語句和ADD關鍵字來增加欄位(欄位),語法為「ALTER TABLE 表名ADD 新欄位名稱資料類型[約束條件];」;這種語法格式會在資料表的末尾新增列(欄位)。

mysql怎麼增加列(字段)

本教學操作環境:windows7系統、mysql8版本、Dell G3電腦。

MySQL 資料表是由行和列構成的,通常把表的「列」稱為欄位(Field),並將表的「行」稱為記錄(Record)。隨著業務的變化,可能需要在已有的表格中新增新的欄位。

在mysql中,可以使用「ALTER TABLE」語句和ADD關鍵字來增加欄位(欄位)。

語法:

ALTER TABLE 表名 ADD 新字段名 数据类型[约束条件];
登入後複製

對文法格式的說明如下:                               # c資料表的名字;

  • 新欄位名稱 :您想要新增的欄位的名字;

  • #資料型別

    :為要新增的欄位能儲存資料的資料型別;
  • [約束條件]

    :是可選的,用來對加的字段進行約束。

這種語法格式預設在表格的最後位置(最後一列的後面)新增欄位。

範例:

我們有一個student 資料表,使用DESC 檢視student 資料表結構

mysql> DESC student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(4)      | YES  |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       |
| sex   | char(1)     | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.01 sec)
登入後複製

使用ALTER TABLE 語句新增一個INT 類型的欄位age,在看看 student表結構

mysql> ALTER TABLE student ADD age INT(4);
Query OK, 0 rows affected (0.16 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> DESC student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(4)      | YES  |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       |
| sex   | char(1)     | YES  |     | NULL    |       |
| age   | int(4)      | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)
登入後複製

可以看出student 表已經添加了age 字段,且該字段在表的最後一個位置,添加字段成功。

那麼如果想要在開頭或中間新增字段,需要怎麼做?

  • 如果希望在開頭位置(第一列的前面)新增字段,那麼需要藉助FIRST

    關鍵字
  • 如果希望在中間位置新增字段,那麼需要藉助AFTER

    關鍵字

語法格式如下:

ALTER TABLE 表名 ADD 新字段名 数据类型 [约束条件] FIRST;

ALTER TABLE 表名 ADD 新字段名 数据类型 [约束条件] AFTER <已经存在的字段名>;
登入後複製

範例:

mysql> ALTER TABLE student ADD stuId INT(4) FIRST;
Query OK, 0 rows affected (0.14 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> DESC student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| stuId | int(4)      | YES  |     | NULL    |       |
| id    | int(4)      | YES  |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       |
| sex   | char(1)     | YES  |     | NULL    |       |
| age   | int(4)      | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)
登入後複製

student 表中添加了一個stuId 字段,且該字段在表中的第一個位置

mysql> ALTER TABLE student ADD stuno INT(11) AFTER name;
Query OK, 0 rows affected (0.13 sec)
Records: 0  Duplicates: 0  Warnings: 0
 
mysql> DESC student;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| stuId | int(4)      | YES  |     | NULL    |       |
| id    | int(4)      | YES  |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       |
| stuno | int(11)     | YES  |     | NULL    |       |
| sex   | char(1)     | YES  |     | NULL    |       |
| age   | int(4)      | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)
登入後複製
student 表中添加了一個stuId 字段,且該字段在name 字段後面的位置

【相關推薦:mysql影片教學

】###

以上是mysql怎麼增加列(字段)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板