如何改變MySQL表的列位置而不遺失列資料?

WBOY
發布: 2023-08-28 19:05:02
轉載
1360 人瀏覽過

如何改變MySQL表的列位置而不遺失列資料?

借助 ALTER TABLE 命令,您可以變更 MySQL 表的列位置而不會遺失資料。語法如下 -

ALTER TABLE yourTableName MODIFY yourColumnName1 data type AFTER yourColumnName2;
登入後複製

為了理解上述概念,讓我們建立一個表格。建立包含某些列的表的查詢如下 -

mysql> create table changeColumnPositionDemo
−> (
−> StudentId int,
−> StudentAddress varchar(200),
−> StudentAge int,
−> StudentName varchar(200)
−> );
Query OK, 0 rows affected (0.72 sec)
登入後複製

讓我們在表中插入一些資料。插入記錄的查詢如下-.

mysql> insert into changeColumnPositionDemo values(101,'US',23,'Johnson');
Query OK, 1 row affected (0.13 sec)

mysql> insert into changeColumnPositionDemo values(102,'UK',20,'John');
Query OK, 1 row affected (0.19 sec)

mysql> insert into changeColumnPositionDemo values(103,'US',22,'Carol');
Query OK, 1 row affected (0.39 sec)

mysql> insert into changeColumnPositionDemo values(104,'UK',19,'Sam');
Query OK, 1 row affected (0.18 sec)
登入後複製

現在您可以藉助 select 語句來顯示所有記錄。查詢如下 -

mysql> select *from changeColumnPositionDemo;
登入後複製

以下是輸出 -

+-----------+----------------+------------+-------------+
| StudentId | StudentAddress | StudentAge | StudentName |
+-----------+----------------+------------+-------------+
|       101 | U              | 23         | Johnson     |
|       102 | UK             | 20         | John        |
|       103 | US             | 22         | Carol       |
|       104 | UK             | 19         | Sam         |
+-----------+----------------+------------+-------------+
4 rows in set (0.00 sec)
登入後複製

這裡是更改列位置而不遺失資料的查詢。我們將「StudentAddress」欄位移至「StudentAge」欄位之後 -

mysql> ALTER TABLE changeColumnPositionDemo MODIFY StudentAddress varchar(200) AFTER StudentAge;
Query OK, 0 rows affected (2.27 sec)
Records: 0 Duplicates: 0 Warnings: 0
登入後複製

上面我們在列名StudentAge之後設定了其中一個欄位StudentAddress。

以下是檢查上述兩列是否已更改且不遺失資料的查詢 -

mysql> select *from changeColumnPositionDemo;
登入後複製

以下是輸出 -

+-----------+------------+----------------+-------------+
| StudentId | StudentAge | StudentAddress | StudentName |
+-----------+------------+----------------+-------------+
|       101 | 23         | US             | Johnson     |
|       102 | 20         | UK             | John        |
|       103 | 22         | US             | Carol       |
|       104 | 19         | UK             | Sam         |
+-----------+------------+----------------+-------------+
4 rows in set (0.00 sec)
登入後複製

以上是如何改變MySQL表的列位置而不遺失列資料?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!