如何在MySQL查詢中使用INSERT INTO ... SELECT語句新增靜態值?


您可以使用INSERT INTO ... SELECT MySQL 查詢新增靜態值。直接在SELECT語句中寫入值,或者可以使用初始化值的變數。

案例1 − 直接在INSERT INTO ... SELECT語句中放置值。語法如下:

INSERT INTO yourSecondTableName(yourColumnName1,yourColumnName2,....N)
   SELECT yourColumnName1 ,yourColumnName2,.....N,yourStaticValue from yourFirstTableName;

案例2 − 使用變數新增。語法如下:

SET @yourVariableName − = yourstaticValue;
   INSERT INTO yourSecondTableName(yourColumnName1,yourColumnName2,....N)
   SELECT yourColumnName1 ,yourColumnName2,.....N,@yourVariableName from yourFirstTableName;

要理解上述語法,您需要建立兩個表。第一個表將包含一些記錄,而第二個表將使用INSERT INTO ... SELECT語句插入第一個表的記錄,並新增一個靜態值。

讓我們建立第一個表。建立表的查詢如下:

mysql> create table First_table
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> FirstValue int,
   -> SecondValue int,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.56 sec)

現在您可以使用INSERT命令在表中插入一些記錄。查詢如下:

mysql> insert into First_table(FirstValue,SecondValue) values(10,14);
Query OK, 1 row affected (0.20 sec)

mysql> insert into First_table(FirstValue,SecondValue) values(12,13);
Query OK, 1 row affected (0.52 sec)

mysql> insert into First_table(FirstValue,SecondValue) values(100,110);
Query OK, 1 row affected (0.14 sec)

mysql> insert into First_table(FirstValue,SecondValue) values(45,55);
Query OK, 1 row affected (0.27 sec)

使用SELECT語句顯示錶中的所有記錄。查詢如下:

mysql> select *from First_table;

以下是輸出:

+----+------------+-------------+
| Id | FirstValue | SecondValue |
+----+------------+-------------+
|  1 |         10 |          14 |
|  2 |         12 |          13 |
|  3 |        100 |         110 |
|  4 |         45 |          55 |
+----+------------+-------------+
4 rows in set (0.00 sec)

讓我們建立第二個表。建立表的查詢如下:

mysql> create table Second_table
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> Value1 int,
   -> Value2 int,
   -> Value3 int,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.81 sec)

上表中有三列,其中兩列將從第一個表獲取值,而第三列將直接或間接獲取值。

INSERT INTO ... SELECT語句的查詢如下:

案例1 − 將靜態值新增到第三列。查詢如下:

mysql> insert into Second_table(Value1,Value2,Value3)
   -> select FirstValue,SecondValue,45 from First_table;
Query OK, 4 rows affected (0.16 sec)
Records − 4 Duplicates − 0 Warnings − 0

這裡,我在第三列添加了45。現在使用SELECT語句檢查表中的所有記錄。查詢如下:

mysql> select *from Second_table;

以下是輸出:

+----+--------+--------+--------+
| Id | Value1 | Value2 | Value3 |
+----+--------+--------+--------+
|  1 |     10 |     14 | 45     |
|  2 |     12 |     13 | 45     |
|  3 |    100 |    110 | 45     |
|  4 |     45 |     55 | 45     |
+----+--------+--------+--------+
4 rows in set (0.00 sec)

案例2 − 使用變數時。查詢如下:

mysql> set @staticValue − = 20;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into Second_table(Value1,Value2,Value3)
   -> select FirstValue,SecondValue,@staticValue from First_table;
Query OK, 4 rows affected (0.19 sec)
Records − 4 Duplicates − 0 Warnings − 0

為我的第三列新增值20。讓我們再次使用SELECT語句檢查表的記錄。查詢如下:

mysql> select *from Second_table;

以下是輸出:

+----+--------+--------+--------+
| Id | Value1 | Value2 | Value3 |
+----+--------+--------+--------+
|  1 |     10 |     14 |     20 |
|  2 |     12 |     13 |     20 |
|  3 |    100 |    110 |     20 |
|  4 |     45 |     55 |     20 |
+----+--------+--------+--------+
4 rows in set (0.00 sec)

更新於:2020年6月30日

12K+ 次瀏覽

啟動你的職業生涯

完成課程獲得認證

開始
廣告