登录
首页 >  数据库 >  MySQL

我们如何将 WHERE 子句与 MySQL INSERT INTO 命令一起使用?

来源:tutorialspoint

时间:2023-09-04 10:50:53 106浏览 收藏

大家好,我们又见面了啊~本文《我们如何将 WHERE 子句与 MySQL INSERT INTO 命令一起使用?》的内容中将会涉及到等等。如果你正在学习数据库相关知识,欢迎关注我,以后会给大家带来更多数据库相关文章,希望我们能一起进步!下面就开始本文的正式内容~

在插入新行的情况下,我们可以使用条件插入,即 WHERE 子句和 INSERT INTO 命令。可以通过以下方式完成 -

借助虚拟表

在这种情况下,我们插入虚拟表中的值以及一些状况。语法如下 -

INSERT INTO table_name(column1,column2,column3,…) Select value1,value2,value3,… From dual WHERE [conditional predicate];

示例

mysql> Create table testing(id int, item_name varchar(10));
Query OK, 0 rows affected (0.15 sec)

mysql> Insert into testing (id,item_name)Select 1,'Book' From Dual Where 1=1;
Query OK, 1 row affected (0.11 sec)
Records: 1 Duplicates: 0 Warnings: 0

mysql> Select * from testing;

+------+-----------+
| id   | item_name |
+------+-----------+
| 1    | Book      |
+------+-----------+

1 row in set (0.00 sec)

在上面的示例中,我们创建了一个表“testing”,为了向其中插入行,我们使用了带有条件的虚拟表对偶。如果条件为真,MySQL 会将行插入到表中,否则不会。

借助相同结构的表

如果我们想插入结构与另一个表相同的表,然后在下面的示例中演示了如何进行条件插入,即如何将 WHERE 子句与 INSERT INTO 语句一起使用。

mysql> Insert into dummy1(id,name)select id, name from dummy Where id =1;
Query OK, 1 row affected (0.06 sec)
Records: 1 Duplicates: 0 Warnings: 0

mysql> select * from dummy;

+------+--------+
| id   | Name   |
+------+--------+
| 1    | Gaurav |
| 2    | Aarav |
+------+--------+

2 rows in set (0.00 sec)

mysql> select * from dummy1;

+------+--------+
| id   | Name   |
+------+--------+
| 1    | Gaurav |
+------+--------+

1 row in set (0.00 sec)

在上面的示例中,我们在表“dummy1”中插入了值,其结构与表“dummy”相同,条件是仅插入“id = 1”的行。

今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>