1. 程式人生 > 實用技巧 >MySQL教程41-MySQL資料表新增欄位

MySQL教程41-MySQL資料表新增欄位

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

MySQL 允許在開頭、中間和結尾處新增欄位。

在末尾新增欄位

一個完整的欄位包括欄位名、資料型別和約束條件。MySQL 新增欄位的語法格式如下:

ALTER TABLE <表名> ADD <新欄位名><資料型別>[約束條件];

對語法格式的說明如下:

  • <表名> 為資料表的名字;
  • <新欄位名> 為所要新增的欄位的名字;
  • <資料型別> 為所要新增的欄位能儲存資料的資料型別;
  • [約束條件] 是可選的,用來對新增的欄位進行約束。

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

注意:這裡我們只新增新的欄位,不關注它的約束條件。

例項1

在 test_db 資料庫中新建 student 資料表,SQL 語句和執行結果如下:

mysql> CREATE TABLE student (
    -> id INT(4),
    -> name VARCHAR(20),
    -> sex CHAR(1));
Query OK, 0 rows affected (0.09 sec) 

使用 DESC 檢視 student 表結構,SQL 語句和執行結果如下:

使用 ALTER TABLE 語句新增一個 INT 型別的欄位 age,SQL 語句和執行結果如下:

由執行結果可以看到,student 表已經添加了 age 欄位,且該欄位在表的最後一個位置,新增欄位成功。

在開頭新增欄位

MySQL 預設在表的最後位置新增新欄位,如果希望在開頭位置(第一列的前面)新增新欄位,那麼可以使用 FIRST 關鍵字,語法格式如下:

ALTER TABLE <表名> ADD <新欄位名> <資料型別> [約束條件] FIRST;

FIRST 關鍵字一般放在語句的末尾。

例項2

使用 ALTER TABLE 語句在表的第一列新增 INT 型別的欄位 stuId,SQL 語句和執行結果如下所示。

由執行結果可以看到,student 表中已經添加了 stuId 欄位,且該欄位在表中的第一個位置,新增欄位成功。

在中間位置新增欄位

MySQL 除了允許在表的開頭位置和末尾位置新增欄位外,還允許在中間位置(指定的欄位之後)新增欄位,此時需要使用 AFTER 關鍵字,語法格式如下:

ALTER TABLE <表名> ADD <新欄位名> <資料型別> [約束條件] AFTER <已經存在的欄位名>;

AFTER的作用是將新欄位新增到某個已有欄位後面。

注意,只能在某個已有欄位的後面新增新欄位,不能在它的前面新增新欄位。

例項3

使用 ALTER TABLE 語句在 student 表中新增名為 stuno,資料型別為 INT 的欄位,stuno 欄位位於 name 欄位的後面。SQL 語句和執行結果如下:

由執行結果可以看到,student 表中已經添加了 stuId 欄位,且該欄位在 name 欄位後面的位置,新增欄位成功。