VALUES or VALUE clause: This clause contains a list of data to be inserted. The order of the data in the data list should correspond to the order of the columns.
SET = ,
= ,
…
This statement is used to directly specify the corresponding column values for certain columns in the table, that is, the column name of the data to be inserted is specified in the SET clause, col_name is the specified column name, and the equal sign The specified data follows, and for unspecified columns, the column value will be specified as the default value of the column.
It can be seen from the two forms of the INSERT statement:
-
The INSERT…VALUES statement can be used to Insert a row of data into the table, or insert multiple rows of data;
-
Use the INSERT…SET statement to specify the value of each column in the inserted row, or specify the value of some columns;
-
The INSERT…SELECT statement inserts data from other tables into the table.
-
The INSERT…SET statement can be used to insert the value of some columns into the table, which is more flexible;
-
The INSERT…VALUES statement can insert multiple pieces of data at one time.
In MySQL, processing multiple inserts with a single INSERT statement is faster than using multiple INSERT statements.
When using a single INSERT statement to insert multiple rows of data, you only need to enclose each row of data in parentheses.
Add values to all fields in the table
Create a course information table tb_courses in the test_db database, including course number course_id, course name course_name, course Credit course_grade and course notes course_info, the input SQL statement and the execution result are as follows.
mysql> CREATE TABLE tb_courses
-> (
-> course_id INT NOT NULL AUTO_INCREMENT,
-> course_name CHAR(40) NOT NULL,
-> course_grade FLOAT NOT NULL,
-> course_info CHAR(100) NULL,
-> PRIMARY KEY(course_id)
-> );
Query OK, 0 rows affected (0.00 sec)
There are two ways to insert values to all fields in the table: one is to specify all field names; the other is to not specify field names at all.
【Example 1】Insert a new record in the tb_courses table, the value of course_id is 1, the value of course_name is “Network”, the value of course_grade is 3, and the value of info is “Computer Network”.
Before performing the insert operation, check the SQL statement and execution result of the tb_courses table as shown below.
mysql> SELECT * FROM tb_courses;
Empty set (0.00 sec)
The query result shows that the content of the current table is empty and there is no data. Next, the operation of inserting data will be performed. The input SQL statement and execution process are as follows.
mysql> INSERT INTO tb_courses
-> (course_id, course_name, course_grade, course_info)
-> VALUES(1, & # 39; Network & # 39;, 3, & # 39; Computer Network & # 39;);
Query OK, 1 rows affected (0.08 sec)
mysql> SELECT * FROM tb_courses;
+-----------+-------------+--------------+------- ----------+
| course_id | course_name | course_grade | course_info |
+-----------+-------------+--------------+------- ----------+
| 1 | Network | 3 | Computer Network |
+-----------+-------------+--------------+------- ----------+
1 row in set (0.00 sec)
You can see that the record was inserted successfully. When inserting data, all fields of the tb_courses table are specified, so new values will be inserted for each field.
The order of the column names behind the INSERT statement may not be the order of the tb_courses table definition, that is, when inserting data, it does not need to be inserted in the order of the table definition, as long as the order of the values is guaranteed to be the same as the order of the column fields .
【Example 2】Insert a new record in the tb_courses table, the value of course_id is 2, the value of course_name is “Database”, the value of course_grade is 3, and the value of info is “MySQL”. The entered SQL statement and execution result are as follows.
mysql> INSERT INTO tb_courses
-> (course_name, course_info, course_id, course_grade)
-> VALUES('Database','MySQL',2,3);
Query OK, 1 rows affected (0.08 sec)
mysql> SELECT * FROM tb_courses;
+-----------+-------------+--------------+------- ----------+
| course_id | course_name | course_grade | course_info |
+-----------+-------------+--------------+------- ----------+
|1 | Network | 3 | Computer Network |
| 2 | Database | 3 | MySQL |
+-----------+-------------+--------------+------- ----------+
2 rows in set (0.00 sec)
When using INSERT to insert data, the column name list column_list is allowed to be empty. At this time, the value list needs to specify a value for each field of the table, and the order of the values must be the same as The fields in the data table are defined in the same order.
【Example 3】Insert a new record in the tb_courses table, the value of course_id is 3, the value of course_name is “Java”, the value of course_grade is 4, and the value of info is “Jave EE”. The entered SQL statement and execution result are as follows.
mysql> INSERT INTO tb_courses
-> VLAUES(3,'Java',4,'Java EE');
Query OK, 1 rows affected (0.08 sec)
mysql> SELECT * FROM tb_courses;
+-----------+-------------+--------------+------- ----------+
| course_id | course_name | course_grade | course_info |
+-----------+-------------+--------------+------- ----------+
| 1 | Network | 3 | Computer Network |
| 2 | Database | 3 | MySQL |
| 3 | Java | 4 | Java EE |
+-----------+-------------+--------------+------- ----------+
3 rows in set (0.00 sec)
There is no insert list specified in the INSERT statement, only a list of values. In this case, the list of values specifies the inserted values for each field column, and the values must be in the same order as the fields are defined in the tb_courses table.
Note: Although the column name of the inserted data can be ignored when using INSERT to insert data, if the value does not contain the column name, the value after the VALUES keyword is not only required to be complete, but also must be in the same order as the column when the table is defined in the same order. If the structure of the table is modified, adding, deleting or changing the position of the column, these operations will make the order of inserting data in this way also change at the same time. If you specify column names, you will not be affected by changes in the table structure.
Add value to the specified field in the table
Insert data for the specified field in the table, which is to insert values into some fields in the INSERT statement, and The values of other fields are the default values when the table is defined.
【Example 4】Insert a new record in the tb_courses table, the value of course_name is “System”, the value of course_grade is 3, and the value of course_info is “Operating System”. The entered SQL statement and execution result are as follows .
mysql> INSERT INTO tb_courses
-> (course_name, course_grade, course_info)
-> VALUES('System',3,'Operation System');
Query OK, 1 rows affected (0.08 sec)
mysql> SELECT * FROM tb_courses;
+-----------+-------------+--------------+------- ----------+
| course_id | course_name | course_grade | course_info |
+-----------+-------------+--------------+------- ----------+
| 1 | Network | 3 | Computer Network |
| 2 | Database | 3 | MySQL |
| 3 | Java | 4 | Java EE |
| 4 | System | 3 | Operating System |
+-----------+-------------+--------------+------- ----------+
4 rows in set (0.00 sec)
You can see that the record was inserted successfully. As the query results show, the course_id field here is automatically added with an integer value of 4. At this time, the course_id field is the primary key of the table and cannot be empty. The system automatically inserts an auto-incremented sequence value for this field. When inserting records, if some fields do not specify the insertion value, MySQL will insert the default value when the field is defined.
Use INSERT INTO…FROM statement to copy table data
INSERT INTO…SELECT…FROM statement is used to quickly retrieve data from one or more tables , and insert this data as row data into another table.
The SELECT clause returns a queried result set, and the INSERT statement inserts the result set into the specified table. The number of fields and the data types of each row of data in the result set must be the same as those to be operated table is completely consistent.
Create a data table tb_courses_new with the same structure as the tb_courses table in the database test_db. The SQL statement and execution process for creating the table are as follows.
mysql> CREATE TABLE tb_courses_new
-> (
-> course_id INT NOT NULL AUTO_INCREMENT,
-> course_name CHAR(40) NOT NULL,
-> course_grade FLOAT NOT NULL,
-> course_info CHAR(100) NULL,
-> PRIMARY KEY(course_id)
-> );
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM tb_courses_new;
Empty set (0.00 sec)
[Example 5] Query all records from the tb_courses table and insert them into the tb_courses_new table. The entered SQL statement and execution result are as follows.
mysql> INSERT INTO tb_courses_new
-> (course_id, course_name, course_grade, course_info)
-> SELECT course_id,course_name,course_grade,course_info
-> FROM tb_courses;
Query OK, 4 rows affected (0.17 sec)
Records: 4 Duplicates: 0 Warnings: 0
mysql> SELECT * FROM tb_courses_new;
+-----------+-------------+--------------+------- ----------+
| course_id | course_name | course_grade | course_info |
+-----------+-------------+--------------+------- ----------+
| 1 | Network | 3 | Computer Network |
| 2 | Database | 3 | MySQL |
| 3 | Java | 4 | Java EE |
| 4 | System | 3 | Operating System |
+-----------+-------------+--------------+------- ----------+
4 rows in set (0.00 sec)
Recommended tutorial: mysql video tutorial
The above is how mysql inserts multiple pieces of data? For more details, please pay attention to other related articles on 1024programmer.com!
——–+————–+——————+
| course_id | course_name | course_grade | course_info |
+———–+————-+————–+——- ———-+
| 1 | Network | 3 | Computer Network |
| 2 | Database | 3 | MySQL |
| 3 | Java | 4 | Java EE |
| 4 | System | 3 | Operating System |
+———–+————-+————–+——- ———-+
4 rows in set (0.00 sec)
Recommended tutorial: mysql video tutorial
The above is how mysql inserts multiple pieces of data? For more details, please pay attention to other related articles on 1024programmer.com!