MySQL 如何在查询中使用INSERT INTO和SELECT时添加静态值
当你使用INSERT INTO SELECT语句时,可以添加静态值。可以直接在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;
要理解上述语法,您需要创建两个表。第一个表格将在表格中有一些记录,而第二个表格将使用插入语句将第一个表格记录插入,并添加静态值。
让我们创建第一个表格。创建表的查询语句如下 –
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)
现在您可以使用插入命令向表格中插入一些记录。查询语句如下 –
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)
阅读更多:MySQL 教程