MySQL中数据插入方法:INSERTINTO,SELECT,SET,REPLACEINTO详解

06-01 1032阅读

在MySQL中,有多种方法可以添加数据。以下是一些常见的方法及其示例。

1. 使用INSERT INTO语句:这是最常用的方法,用于向表中插入新记录。

  • 语法:
    INSERT INTO table_name (column1, column2, column3, ...) 
    VALUES (value1, value2, value3, ...);
    
    • 示例:

      假设我们有一个名为 e_student 的表,包含以下列:id,name,age,grade。我们可以使用以下语句向表中插入一条新记录:

      INSERT INTO e_student (id, name, age, grade)
      VALUES (1, '张三', 6, '一年级');
      
      • 插入数据后 e_student 结果
        +--------+-----+--------+---------+
        |  id | name | age |  grade  |
        +--------+-----+--------+---------+
        |  1  |  张三 |  6  | 一年级  |
        

        2. 使用INSERT INTO SELECT语句:此方法允许您从一个表复制数据并将其插入到另一个表中。

        • 语法:
          INSERT INTO table2 (column1, column2, ...)
          SELECT column1, column2, ...
          FROM table1
          WHERE condition;
          
          • 示例:

            假设我们有两个表:e_student 和 e_student_temp。我们可以使用以下语句将已毕业的学生从 e_student 表复制到 e_student_temp 表:

            INSERT INTO e_student_temp (id, name, age, grade)
            SELECT id, name, age, grade
            FROM e_student
            WHERE id = 1;
            
            • 插入数据后 e_student_temp 结果
              +--------+-----+--------+---------+
              |  id | name | age |  grade  |
              +--------+-----+--------+---------+
              |  1  |  张三 |  6  | 一年级  |
              

              3. 使用INSERT INTO … SET这种方法允许你使用SET关键字为表中的列指定值。

              • 语法:
                INSERT INTO 表名 SET 列1 = 值1, 列2 = 值2, ...;
                
                • 示例:

                  使用上面的 e_student 表。

                  INSERT INTO e_student SET id = 2, name = '李四', age = 8, grade = '三年级';
                  
                  • 插入数据后 e_student 结果
                    +--------+-----+--------+---------+
                    |  id | name | age |  grade  |
                    +--------+-----+--------+---------+
                    |  1  |  张三 |  6  | 一年级  |
                    |  2  |  李四 |  8  | 三年级  |
                    

                    4. 批量插入,可以使用单个INSERT INTO语句插入多行数据。

                    • 语法:
                      INSERT INTO 表名 (列1, 列2, 列3, ...)  
                      VALUES   
                      (值1a, 值2a, 值3a, ...),  
                      (值1b, 值2b, 值3b, ...),  
                      ...;
                      
                      • 示例:

                        使用上面的 e_student 表。

                        INSERT INTO e_student (id, name, age, grade)
                        VALUES 
                        (3, '王五', 9, '四年级'),
                        (4, '张六', 10, '五年级'),
                        (5, '李七', 11, '六年级');
                        
                        • 插入数据后 e_student 结果
                          +--------+-----+--------+---------+
                          |  id | name | age |  grade  |
                          +--------+-----+--------+---------+
                          |  1  |  张三 |  6  | 一年级  |
                          |  2  |  李四 |  8  | 三年级  |
                          |  3  |  王五 |  9  | 四年级  |
                          |  4  |  张六 | 10  | 五年级  |
                          |  5  |  李七 | 11  | 六年级  |
                          

                          5. 使用REPLACE INTO语句:此方法类似于INSERT INTO,但它首先检查表中是否已存在具有相同主键或唯一索引值的记录。如果存在,则删除旧记录并插入新记录;如果不存在,则插入新记录。

                          • 语法:
                            REPLACE INTO table_name (column1, column2, column3, ...)
                            VALUES (value1, value2, value3, ...);
                            
                            • 示例:

                              假设我们有一个名为 e_student 的表,包含以下列:id, name, age和grade。我们可以使用以下语句替换表中的一条记录

                              REPLACE INTO e_student (id, name, age, grade)
                              VALUES 
                              (1, '张八', 7, '二年级'),
                              (6, '张九', 9, '四年级');
                              
                              • 插入数据后 e_student 结果
                                +--------+-----+--------+---------+
                                |  id | name | age |  grade  |
                                +--------+-----+--------+---------+
                                |  1  |  张八 |  6  | 二年级  |
                                |  2  |  李四 |  8  | 三年级  |
                                |  3  |  王五 |  9  | 四年级  |
                                |  4  |  张六 | 10  | 五年级  |
                                |  5  |  李七 | 11  | 六年级  |
                                |  6  |  张九 |  9  | 四年级  |
                                

                                6. 注意事项

                                • 确保你插入的数据类型与表中的列数据类型匹配。
                                • 如果表中有自增列(如上面的id列),你可以省略该列的值,MySQL会自动为你生成一个唯一的值。
                                • 使用INSERT INTO … SELECT时,确保选择的列与插入的列顺序和类型相匹配。
                                • 在批量插入时,确保每一行的数据都是完整的,并且格式正确。
                                • 如果你的表有约束(如主键约束、唯一约束等),确保插入的数据不违反这些约束。
                                MySQL中数据插入方法:INSERTINTO,SELECT,SET,REPLACEINTO详解
                                (图片来源网络,侵删)
                                MySQL中数据插入方法:INSERTINTO,SELECT,SET,REPLACEINTO详解
                                (图片来源网络,侵删)
                                MySQL中数据插入方法:INSERTINTO,SELECT,SET,REPLACEINTO详解
                                (图片来源网络,侵删)
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。

目录[+]

取消
微信二维码
微信二维码
支付宝二维码