• Mysql中数据的增删改


    前言

    对于数据库来说,分几个等级,一个是容器级别的(库、表等),一个是数据级别的,今天所要讨论的就是数据的增、删、改,对于数据的查找,我们已经做了较为详细的分析。

    1、增(插入数据)INSERT

    使用INSERT语句向表中插入数据。

    1.1 VALUES的方式添加

    • 为表的所有字段按默认顺序插入数据
    • 为表的指定字段插入数据,就是在INSERT语句中只向部分字段中插入值,而其他字段的值为表定义时的默认值。在 INSERT 子句中随意列出列名,但是一旦列出,VALUES中要插入的value1,…valuen需要与column1,…columnn列一一对应。如果类型不同,将无法插入,并且MySQL会产生错误。

    1.2 与SELECT语句相配合

    在insert语句中加入子查询, 将SELECT语句查询结果插入到表中,可以快速的实现一个表或多个表向一个表中插入多行
    列多少不一致添加不成功,列参数不一致,添加不成功。

    INSERT INTO 目标表名
    (tar_column1 [, tar_column2,, tar_columnn])
    SELECT
    (src_column1 [, src_column2,, src_columnn])
    FROM 源表名
    [WHERE condition]
    --子查询中的值列表应与 INSERT 子句中的列名对应。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2、删 DELETE

    table_name指定要执行删除操作的表;“[WHERE ]”为可选参数,指定删除条件,如果没有WHERE子句,DELETE语句将删除表中的所有记录。

    DELETE FROM table_name [WHERE <condition>];
    
    • 1

    注意如果删除的列是有外键约束的,可能会产生数据完整性错误

    3、改 UPDATE

    可以一次更新多条数据。
    如果需要回滚数据,需要保证在DML前,进行设置:SET AUTOCOMMIT = FALSE;

    UPDATE 表名
    SET 字段名=?
    [WHERE condition]
    
    • 1
    • 2
    • 3

    注意如果修改的列是有外键约束的,可能会产生数据完整性错误

    4、计算列

    简单来说就是某一列的值是通过别的列计算得来的。例如,a列值为1、b列值为2,c列
    不需要手动插入,定义a+b的结果为c的值,那么c就是计算列,是通过别的列计算得来的

    设定方式

    CREATE TABLE 和 ALTER TABLE 中都支持增加计算列

    CREATE TABLE tb1(
    id INT,
    a INT,
    b INT,
    c INT GENERATED ALWAYS AS (a + b) VIRTUAL
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    FastDFS-02-JavaAPI
    自适应 t 分布与动态边界策略改进的算术优化算法-附代码
    vue面试题
    定点数原码一位乘法
    核心函数--少儿编程
    【计算机基础】数据结构一览
    基于WPF重复造轮子,写一款数据库文档管理工具(一)
    OpenAI 推出 DALL·E 3 配合 ChatGPT 无需复杂提示词即可作画
    “攻城狮”如何写高逼格的代码
    2022年R1快开门式压力容器操作考试模拟100题及答案
  • 原文地址:https://blog.csdn.net/cillian_bao/article/details/125503707