码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mysql数据库基础:DML数据操作语言


    文章目录

    • DML语言
      • 1、insert插入语句
        • 语法
      • 2、update更新/修改语句
        • 2.1 修改单表的记录
        • 2.2 修改多表的记录
      • 3、delete/truncate删除语句
        • 语法

    DML语言

    1、insert插入语句

    语法

    • 第一种方式:经典插入
    insert into 表名(列名1,列名2,...) values (值1,值2,...)
    
    • 1

    注意点:
    1、插入的值的类型要与列的类型一致或兼容
    2、不可以为null的列必须插入值,可以为null的列(nullable)要么将null作为值插入,要么可以同时省略列和列对应的值不写。
    3、列的顺序是可以调换的,但要求对应的值也同时匹配调换
    4、列数和值的个数必须一致
    5、可以省略列名,但要求列的顺序和表中列的顺序一致,并且值为null的不可以省略

    • 第二种方式
    insert into 表名
    set 列名=值,列名=值,...
    
    • 1
    • 2

    对比这两种插入方式
    1、方式一可以支持插入多行,方式2不支持

    insert into 表名
    values (值1,值2,...)
    ,(值1,值2,...)
    ,(值1,值2...);
    
    • 1
    • 2
    • 3
    • 4

    2、方式一支持子查询,方式二不支持子查询

    insert into 表名(列名1,列名2,...)
    select语句
    
    • 1
    • 2

    所以方式一使用的场景更多

    2、update更新/修改语句

    2.1 修改单表的记录

    • 语法
    update 表名
    set 列=新值,列=新值,...
    where 筛选条件;
    
    • 1
    • 2
    • 3
    • 实例
    # 修改beauty表中姓唐的女生的电话为13887888881
    update beauty set phone = '13887888881'
    where name like '唐%';
    
    # 修改boys表中id号为2的名称为张飞,年龄为22
    update boys set name = '张飞',age = 22
    where id = 2;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2.2 修改多表的记录

    • 语法
    update 表1 别名
    inner|left|right join 表2 别名
    on 连接条件
    set 列=值,...
    where 筛选条件
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 案例
    # 修改张无忌的女朋友的手机号为114
    update boys b
    inner join beauty b
    on bo.`id`=b.`boyfrind_id`
    set b.`phone`='114'
    where bo.`boyName`='张无忌';
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    3、delete/truncate删除语句

    语法

    • delete语句

    作用:删除表中的数据

    1、单表的删除

    # 删除表中所有数据
    delete from 表名;
    # 删除表中指定条件的数据
    delete from 表名 where 筛选条件;
    
    • 1
    • 2
    • 3
    • 4

    例题:

    # 删除手机号以9结尾的女生信息
    delete from beauty where phone like '%9';
    
    • 1
    • 2

    2、多表的删除

    # 删除张无忌的女朋友的信息
    delete 表1的别名,表2的别名
    from 表1,表2
    inner|left|right join 表2 别名
    on 连接条件
    where 筛选条件;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    例题:

    # 删除张无忌的女朋友的信息
    delete b
    from beauty b
    inner join boys bo
    on b.`boyfriend_id`=bo.`id`
    where bo.`boyName`='张无忌';
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • truncate语句

    作用:删除表中所有数据

     truncate table 表名;
    
    • 1

    delete和truncate语句的区别
    1、delete可以加where条件,truncate不能加
    2、truncate删除效率比delete高
    3、如果要删除的表中有自增长列,如果用delete删除后,再插入数据,自增长列的值从断点开始,而truncate删除后,再插入数据,自增长列的值从1开始
    4、truncate删除没有返回值,delete删除有返回值
    5、truncate删除不能回滚,delete删除可以回滚

  • 相关阅读:
    Alamofire源码分析 - POST请求
    哈工大李治军老师操作系统笔记【12】:CPU调度策略(Learning OS Concepts By Coding Them !)
    微信小程序使用canvas绘图,圆形头像,网络背景图,文字,虚线,直线
    Java BigInteger比Long更大的整数自增转字符串存储
    零难度!台式电脑如何连接蓝牙耳机?简单几步完成
    面了一个4年经验的测试工程师,自动化都不会也要15k,我真是醉了...
    数据读取与保存Sequence文件_大数据培训
    如何保证数据库与缓存的数据一致性
    et al和etc区别
    Greenplum 实用工具-gpaddmirrors
  • 原文地址:https://blog.csdn.net/lalala_dxf/article/details/125472451
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号