MySQL 系统学习系列 - SQL 语句 DML 语句的使用《MySQL系列篇-02》

SQL语句DML

数据库DML操作

0. MySQL中大小写问题[tip]:

  • 1.数据库名与表名是严格区分大小写的 (window不区分)
  • 2.表的别名是严格区分大小写的(如stu as s)(window不区分)
  • 3.列名忽略大小写
  • 4.变量名也是严格区分大小写

1. 插入数据

  • 其中分别可以使用全列插入、缺省插入与批量插入三种方式

sql 复制代码
# 全列插入:INSERT INTO 表名 VALUES(v1,v2,v3,...)
  INSERT INTO stu VALUES(1,'kong',18);
  INSERT INTO stu VALUES(2,'deng',18);
  
# 缺省插入 [即直插入指定列的数据]
  # INSERT INTO 表名(c1,c2,c3,..) VALUES(v1,v2,v3,..)  [其中c1等是指定所要添加数据的列-主要约束问题]
  # 使用缺省插入需要主要有些列是否为非空的
    INSERT INTO stu(id,name) VALUES(0,'wang');
    
# 批量插入 [全列插入多行数据]
  # 全列批量插入:INSERT INTO 表名 VALUES(v1-1,v1-2,...),(v2-1,v2-2,...),.......
    INSERT INTO stu VALUES(0,'v1',1),(0,'v2',2),(0,'v3',3);
  # 缺省值批量插入:INSERT INTO 表名(c1,c2,..) VALUES(v1-1,v1-2,..),(v2-1,v2-2,..),....
    INSERT INTO stu(id,name) VALUES(0,'id1'),(0,'id2');
  
# 批量插入中也可以存在全列插入与缺省插入两种方式,使用方法与上面的无异

2. 更新数据update

  • 更新数据也可以理解为是修改数据:update 表名 set 列1=值1,...... where 条件;

sql 复制代码
# 下面该语句表示更新stu表中的name为kong的数据为new_kong
  UPDATE stu SET name='new_kong' where name='kong'; 
  
# 同时修改多列
  UPDATE stu SET name='kong',age=3 WHERE name='new_kong';
  
    # 当然上面的语句也可以不加 where 条件语句,不过风险会比较大

3. 删除数据

  • delete语句删除

    sql 复制代码
    # 清空表中所有的数据:DELETE FROM 表名
      DELETE FROM stu; # 清空stu表中的所有数据
      
    # 清空表中符合条件的数据:DELETE FROM 表名 WHERE 条件
      DELETE FROM stu WHERE age<7; # 清空stu表中所有age小于7的数据
  • truncate语句删除

    • truncate也是删除数据,但是不可以加where(即只能清空表中所有的信息),执行效率要比delete要高

    sql 复制代码
    # 清空表中所有的数据:TRUNCATE FROM 表名
     TRUNCATE TABLE stu; # 清空stu表中的所有数据
  • delete与truncate语句的区别

    • delete可以加where条件判断使用,来指定删除符合某一个条件的数据 - 而truncate不能加where语句
    • truncate比delete效率要高 缺:不能加where
  • [扩]删除表(整张表都会被删除):drop table 表名

物理删除和逻辑删除

物理删除: 就是将数据从数据库中彻底删除(delete操作属于物理删除,物理删除的数据无法恢复,对于一些重要的数据,还是建议使用逻辑删除)

逻辑删除:

  • 逻辑删除本质是修改(UPDATE)操作,对于重要数据表,增加一个isDelete字段,一般默认为0(没有被删除的的意思),该字段逻辑上表示该条数据是否被删除,真实情况是在数据库中本条数据还存在

    sql 复制代码
    create table student(
        id int not nul1 auto_increment primary key,
        age int,
        name char(20).
        isDelete bit default 0
        engine=innodb defaut charset=utf8;
    )
  • 也可以理解为是添加了一个回收站,并非是真正的删除

相关推荐
bug攻城狮3 分钟前
SaaS多租户架构实践:字段隔离方案(共享数据库+共享Schema)
mysql·架构·mybatis·springboot·1024程序员节
摘星编程31 分钟前
【成长纪实】HarmonyOS Next学习地图:新手避坑指南与核心知识点拆解
学习·华为·harmonyos·鸿蒙开发
l1t32 分钟前
利用DuckDB SQL求解集合数学题
数据库·sql·算法·集合·duckdb
siriuuus41 分钟前
MySQL 慢查询日志及优化
mysql·1024程序员节
筵陌43 分钟前
MYSQL表的操作
数据库·mysql·1024程序员节
华仔啊2 小时前
这20条SQL优化方案,让你的数据库查询速度提升10倍
数据库·后端·mysql
ps酷教程3 小时前
mysql的 in 用法
mysql
自由会客室3 小时前
Ubuntu 24.04上安装MySQL 8.0
数据库·mysql
kali-Myon3 小时前
NewStarCTF2025-Week3-Web
sql·安全·web安全·php·ctf
deng-c-f4 小时前
Linux C/C++ 学习日记(32):协程(二):Ntyco源码解析
学习·协程·ntyco