共計 3003 個字符,預計需要花費 8 分鐘才能閱讀完成。
這篇文章主要講解了“mysql 如何增加列”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學習“mysql 如何增加列”吧!
在 mysql 中,可以使用“ALTER TABLE”語句和 ADD 關鍵字來增加列(字段),語法為“ALTER TABLE 表名 ADD 新字段名 數據類型 [約束條件];”;這種語法格式會在數據表的末尾添加列(字段)。
本教程操作環境:windows7 系統、mysql8 版本、Dell G3 電腦。
MySQL 數據表是由行和列構成的,通常把表的“列”稱為字段(Field),把表的“行”稱為記錄(Record)。隨著業務的變化,可能需要在已有的表中添加新的字段。
在 mysql 中,可以使用“ALTER TABLE”語句和 ADD 關鍵字來增加列(字段)。
語法:
ALTER TABLE 表名 ADD 新字段名 數據類型 [約束條件];
對語法格式的說明如下:
表名:為數據表的名字;
新字段名:為所要添加的字段的名字;
數據類型:為所要添加的字段能存儲數據的數據類型;
[約束條件]:是可選的,用來對添加的字段進行約束。
這種語法格式默認在表的最后位置(最后一列的后面)添加新字段。
示例:
我們有一個 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 如何增加列這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關知識點的文章,歡迎關注!