如何在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)
广告