当前位置:网站首页>MySQL insert free column
MySQL insert free column
2022-04-23 02:46:00 【Zero】
MySQL Insert data ( Add data )-INSERT
Basic grammar :
INSERT There are two grammatical forms of sentences , Namely INSERT…VALUES Statement and INSERT…SET sentence .
1、INSERT…VLAUES sentence
INSERT VLAUES The syntax of is as follows :
INSERT INTO < Table name >
[< Name 1>[,< Name 2>,…< Name n>]]
VLAUES( value 1)[…( value n)];
The grammar is as follows .
< Table name >: Specifies the name of the table being manipulated .
< Name >: Specify the name of the column to insert the data . If you insert data into all the columns in the table , Then all column names can be omitted , Direct adoption INSERT< Table name >VALUES(…) that will do .
VALUES or VALUE Clause : This clause contains the list of data to insert . The order of the data in the data list corresponds to the order of the columns .
2、INSERT … SET sentence
INSERT INTO< Table name >
SET < Name 1> = < value 1>,
< Name 2> = < value 2>,
...
This statement is used to specify the corresponding column values directly to some columns in the table , The column name of the data to be inserted is in SET Clause ,col_name For the specified column name , After the equal sign is the specified data , And for unspecified Columns , The column value is specified as the default value for that column .
from INSERT Two forms of statements can be seen :
Use INSERT…VALUES Statement can insert a row of data into a table , You can also insert multiple rows of data ;
Use INSERT…SET Statement can specify the value of each column in the inserted row , You can also specify the values of some columns ;
INSERT…SELECT Statement to insert data from other tables into a table .
use INSERT…SET Statement can insert the values of some columns into the table , This way is more flexible ;
INSERT…VALUES Statement can insert more than one piece of data at a time .
stay MySQL in , Use single INSERT Statements handle multiple insertions rather than using multiple INSERT Faster sentences .
When using a single INSERT When a statement inserts multiple rows of data , Just enclose each row of data in parentheses .
Add values to the table :
Create a course_db The database of , Create a... In this database tb_courses Table of , Include course number course_id、 Course name course_name、 course credit course_grade And course notes course_info;
There are two ways to insert values into all fields in the table : One is to specify all field names ; The other is not to specify the field name at all .
1、INSERT VALUES Insert columns in order
【 example 1】 stay tb_courses Insert a new record into the table ,course_id The value is 1,course_name The value is “Network”,course_grade The value is 3,info The value is “Computer Network”.
Before performing the insert operation , see tb_courses Tabular SQL The statement and execution results are as follows .
The query result shows that the content of the current table is empty , No data , Next, perform the operation of inserting data , Input SQL The statement and execution process are as follows .
You can see that the record is inserted successfully . When inserting data , It specifies tb_courses All fields of the table , Therefore, a new value will be inserted for each field .
2、INSERT…VALUES Custom order specifies column insertion
INSERT The order of column names after the statement may not be tb_courses The order in which the table is defined , When inserting data , There is no need to insert... In the order defined by the table , As long as the order of values is the same as that of column fields .
【 example 2】 stay tb_courses Insert a new record into the table ,course_id The value is 2,course_name The value is “Database”,course_grade The value is 3,info The value is “MySQL”. Input SQL The statement and execution results are as follows .
3、INSERT…VALUES Insert without specifying columns
Use INSERT When inserting data , Allow list of column names column_list It's empty , In this case, you need to specify a value for each field of the table in the value list , And the order of values must be the same as that of fields in the data table .
【 example 3】 stay tb_courses Insert a new record into the table ,course_id The value is 3,course_name The value is “JAVA”,course_grade The value is 4,info The value is “Jave EE”. Input SQL The statement and execution results are as follows .
INSERT Statement does not specify an insert list , There is only one list of values . under these circumstances , The value list specifies the inserted value for each field column , And the order of these values must be the same as tb_courses The fields in the table are defined in the same order .
Be careful : Although the use of INSERT When inserting data, you can ignore the column name of the inserted data , If the value does not contain the column name , be VALUES The value after the keyword is not only required to be complete , And the order must be the same as that of the columns when the table is defined . If the structure of the table is modified , Add columns 、 Delete or position change operation , These operations will change the order of inserting data in this way at the same time . If you specify a column name , It will not be affected by the change of table structure .
4、INSERT…VALUES Specify column insertion
Insert data for the specified fields of the table , Is in INSERT Statement inserts values into only some fields , The values of other fields are the default values when the table is defined .
【 example 4】 stay tb_courses Insert a new record into the table ,course_name The value is “System”,course_grade The value is 3,course_info The value is “Operating System”, Input SQL The statement and execution results are as follows .
You can see that the record is inserted successfully . If the query result shows , there course_id The field automatically adds an integer value 4. At this moment course_id The field is the primary key of the table , Can't be empty , The system automatically inserts the self increasing sequence value for this field . When inserting a record , If some fields do not specify an insertion value ,MySQL The default value when the field definition is inserted .
5、INSERT …SET Specify column insertion
【 example 5】 stay tb_courses Insert a new record into the table ,course_name The value is “Python”,course_grade The value is 6,course_info The value is “Python”, Input SQL The statement and execution results are as follows .
6、INSERT …VALUES Insert multiple lines at the same time
stay MySQL in , Use single INSERT Statements handle multiple insertions rather than using multiple INSERT Faster sentences . When using a single INSERT When a statement inserts multiple rows of data , Just enclose each row of data in parentheses .
【 example 6】 stay tb_courses Insert a new record into the table ,course_name The value is “C”、“C”,course_grade The value is 8、9,course_info The value is “C#”、“C++”, Input SQL The statement and execution results are as follows .
INSERT INTO…SELECT…FROM Statement is used to quickly retrieve data from one or more tables , And insert the data as row data into another table .
SELECT Clause returns the result set of a query ,INSERT Statement to insert the result set into the specified table , The number of fields per row of data in the result set 、 The data type of the field must be exactly the same as the table being operated .
In the database course_db Create a with tb_courses Data table with the same table structure tb_courses_new, Create a table of SQL The statement and execution process are as follows .
7、 The blank table specifies that the columns are copied completely
【 example 7】 from tb_courses Query all records in the table , And insert it into tb_courses_new In the table . Input SQL The statement and execution results are as follows .
In the database course_db Create a with tb_courses Data table with the same table structure tb_courses_new2, Create a table of SQL The statement and execution process are as follows .
8、 Blank tables do not specify columns to copy completely
【 example 8】 from tb_courses Query all records in the table , And insert it into tb_courses_new2 In the table . Input SQL The statement and execution results are as follows .
9、 Copy one or more rows from one table to another table
【 example 9】 Will table tb_courses in course_id by 6 and 7 Copy rows to table tb_courses_new in , Input SQL The statement and execution results are as follows .
Tips :id(auto increment) in , When inserting , Insert failed due to incorrect operation , When reinserting after modification ,course_id The value of will not increase in order ; This is because insert After failure ,id Has resulted in an automatic increase in id Discontinuities in the display ; Add link description
版权声明
本文为[Zero]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204220744162929.html
边栏推荐
- Rhcsa day 3 operation
- [XJTU計算機網絡安全與管理]第二講 密碼技術
- MySQL JDBC programming
- Difference between relative path and absolute path (often asked in interview)
- 高效音乐格式转换工具Music Converter Pro
- Deploying sbert model based on torchserve < semantic similarity task >
- [suggestion collection] hematemesis sorting out golang interview dry goods 21 questions - hanging interviewer-1
- How to prevent leakage of operation and maintenance data
- Target narak
- [unity3d] rolling barrage effect in live broadcasting room
猜你喜欢
随机推荐
JZ76 删除链表中重复的结点
Planning code ROS migration POMDP prediction planning (I)
全局、独享、局部路由守卫
Slave should be able to synchronize with the master in tests/integration/replication-psync.tcl
Parental delegation model [understanding]
Interim summary (Introduction + application layer + transportation layer)
ROP Emporium x86_64 7~8题
C语言 171. 最近回文数
JZ35 复杂链表的复制
工业互联网+危化安全生产综合管理平台怎样建
Cuisine leetcode
hack the box optimum靶机
Suggestion: block reference sorting is in the order of keywords
Log cutting - build a remote log collection server
Flink stream processing engine system learning (I)
MySQL function syntax
Rhcsa day 4 operation
MySQL / SQL Server判断表或临时表存在则删除
JZ35 replication of complex linked list
leangoo脑图-共享式多人协作思维导图工具分享