zoukankan      html  css  js  c++  java
  • mysql insert的几种情况

    一 普通单条插入:

    像如下表中插入数据:

    id是自动增长的主键。

    INSERT INTO student_score (student_name, score, SUBJECT) VALUES ('张三', 90, '语文');
    

     结果如下:

    mysql> SELECT * FROM student_score;
    +----+--------------+-------+---------+
    | id | student_name | score | subject |
    +----+--------------+-------+---------+
    |  1 | 张三         |    90 | 语文    |
    +----+--------------+-------+---------+
    1 row in set

    二 批量插入:

    INSERT INTO student_score (student_name, score, SUBJECT)
    VALUES
        ('李四', 95, '语文'),
        ('王五', 98, '语文');

    结果如下:

    mysql> SELECT * FROM student_score;
    +----+--------------+-------+---------+
    | id | student_name | score | subject |
    +----+--------------+-------+---------+
    |  1 | 张三         |    90 | 语文    |
    |  2 | 李四         |    95 | 语文    |
    |  3 | 王五         |    98 | 语文    |
    +----+--------------+-------+---------+
    3 rows in set

    三 将数据从一个表插入另一个表

    首先清空student_score表,student_score_record的数据如下:

    mysql> SELECT * FROM student_score_record;
    +----+--------------+-------+---------+------------+
    | id | student_name | score | subject | test_date  |
    +----+--------------+-------+---------+------------+
    |  1 | 张三         |     1 | 语文    | 2020-12-10 |
    |  2 | 李四         |     2 | 语文    | 2020-12-11 |
    |  3 | 王五         |     3 | 语文    | 2020-12-11 |
    +----+--------------+-------+---------+------------+
    3 rows in set

    现需要将student_score_record的相关数据插入到student_score中:

    INSERT INTO student_score (student_name, score, SUBJECT) SELECT
        student_name,
        score,
        SUBJECT
    FROM
        student_score_record;

    结果如下:

    mysql> SELECT * FROM student_score;
    +----+--------------+-------+---------+
    | id | student_name | score | subject |
    +----+--------------+-------+---------+
    |  7 | 张三         |     1 | 语文    |
    |  8 | 李四         |     2 | 语文    |
    |  9 | 王五         |     3 | 语文    |
    +----+--------------+-------+---------+
    3 rows in set

    四 将数据从多个关联表插入一个表

    首先清空student_score表,student表的数据如下:

    mysql> SELECT * FROM `student`;
    +----+--------------+------------+
    | id | student_name | student_id |
    +----+--------------+------------+
    |  1 | 张三         |          1 |
    |  2 | 李四         |          2 |
    |  3 | 王五         |          3 |
    +----+--------------+------------+
    3 rows in set

    student_id_score_record表的数据如下:

    mysql> SELECT * FROM `student_id_score_record`;
    +----+------------+-------+---------+
    | id | student_id | score | subject |
    +----+------------+-------+---------+
    | 10 |          1 |    11 | 语文    |
    | 11 |          2 |    12 | 语文    |
    | 12 |          3 |    13 | 语文    |
    +----+------------+-------+---------+
    3 rows in set

    现在将student和student_id_score_record的关联信息插入到student_score表中:

    INSERT INTO student_score (student_name, score, SUBJECT) SELECT
        student.student_name,
        student_id_score_record.score,
        student_id_score_record.`subject`
    FROM
        student
    INNER JOIN student_id_score_record ON student.id = student_id_score_record.student_id;

    结果如下:

    mysql> SELECT * FROM student_score;
    +----+--------------+-------+---------+
    | id | student_name | score | subject |
    +----+--------------+-------+---------+
    | 10 | 张三         |    11 | 语文    |
    | 11 | 李四         |    12 | 语文    |
    | 12 | 王五         |    13 | 语文    |
    +----+--------------+-------+---------+
    3 rows in set

    五 将数据从其他表插入一个表

    还是四中的例子,不过这次换种写法(此写法主要目的是测试将几个独立表的不同字段插入同一个表时如何处理):

    INSERT INTO student_score (student_name, score, SUBJECT)
    VALUES
        (
            (
                SELECT
                    student_name
                FROM
                    student
                WHERE
                    student_id = 1
            ),
            (
                SELECT
                    score
                FROM
                    student_id_score_record
                WHERE
                    student_id = 1
            ),
            '语文'
        );

    结果如下:

    mysql> SELECT * FROM student_score;
    +----+--------------+-------+---------+
    | id | student_name | score | subject |
    +----+--------------+-------+---------+
    | 14 | 张三         |    11 | 语文    |
    +----+--------------+-------+---------+
    1 row in set

     

  • 相关阅读:
    EasyUI combox实现联动
    房费制(一)——上下机、总结
    6、Cocos2dx 3.0游戏开发的基本概念找个小三场比赛
    java 集装箱 arraylist 用法
    涂料动漫学习笔记(一)
    cocos2d-x plist在拍照
    Hadoop与HBase中遇到的问题(续)java.io.IOException: Non-increasing Bloom keys异常
    Java用ZIP格式压缩和解压缩文件
    Unix/Linux环境C编程新手教程(41) C语言库函数的文件操作具体解释
    Oracle OS认证和口令文件认证方法
  • 原文地址:https://www.cnblogs.com/silenceshining/p/14130861.html
Copyright © 2011-2022 走看看