【MySQL基础随缘更系列】DML语句

在这里插入图片描述

文章目录

    • 一、表记录操作-上
      • 1.1、DML概述
      • 1.2、插入记录
    • 二、表记录操作-下
      • 2.1、更新记录
      • 2.2、删除记录

🌈你好呀!我是 山顶风景独好
🎈欢迎踏入我的博客世界,能与您在此邂逅,真是缘分使然!😊
🌸愿您在此停留的每一刻,都沐浴在轻松愉悦的氛围中。
📖这里不仅有丰富的知识和趣味横生的内容等您来探索,更是一个自由交流的平台,期待您留下独特的思考与见解。🌟
🚀让我们一起踏上这段探索与成长的旅程,携手挖掘更多可能,共同进步!💪✨

数据操纵语言DML(Data Manipulation Language),用户通过它可以实现对数据库的基本操作。就是我们最经常用到的UPDATE、INSERT、DELETE。 主要用来对数据库的数据进行一些操作。

一、表记录操作-上

1.1、DML概述

DML 操作是指对数据库中表记录的操作,主要包括表记录的插入(insert)、更新(update)和删除(delete),是开发人员日常使用最频繁的操作。

1.2、插入记录

格式:
insert into 数据库表名 [字段名列表] values(字段值列表)

说明:

insert into 数据库表名: 指定增加记录的表

[字段名列表]: 表示要给那些字段加入字段值,没有,就为所有字段

values(字段值列表): 表示为对应的字段加入对应的字段值

为所有字段插入值

格式:
insert into 数据库表名(字段名1,字段名2...,字段名n)values(字段值1,字段值2...,字段值n);
或
insert into 数据库表名 values(字段值1,字段值2...,字段值n);

案例:

#指定所有字段插入记录
mysql> insert into student(id,sname,birthday)values(1,"林志颖","1974-10-18");
Query OK, 1 rows affected (0.03 秒)
#不指定字段,默认所有字段插入记录
mysql> insert into student values(2,"郭德纲","1973-01-18");
Query OK, 1 rows affected (0.01 秒)
#查看数据库表中所有记录
mysql> select * from student;
+------+-----------+------------+
| id   | sname     | birthday   |
+------+-----------+------------+
| 1    | 林志颖 | 1974-10-18 |
| 2    | 郭德纲 | 1973-01-18 |
+------+-----------+------------+
2 行于数据集 (0.01 秒)

插入部分字段值

格式:
insert into 数据库表名(字段名1,字段名2...)values(字段值1,字段值2...);
#注意:没有给定字段的值,为null;

案例:

#插入部分字段值
mysql> insert into student(id,sname)values(3,"柳岩");
Query OK, 1 rows affected (0.01 秒)
#查看数据库表中所有记录
mysql> select * from student;
+------+-----------+------------+
| id   | sname     | birthday   |
+------+-----------+------------+
| 1    | 林志颖 | 1974-10-18 |
| 2    | 郭德纲 | 1973-01-18 |
| 3    | 柳岩    | NULL       |
+------+-----------+------------+
3 行于数据集 (0.01 秒)

注意:

只插入部份字段值时,前面必须带字段名字。

mysql> insert into student values(4,"王宝强");
Column count doesn't match value count at row 1#列计数与第1行的值计数不匹配

二、表记录操作-下

2.1、更新记录

格式:
update 数据库表名 set 字段名1=字段值1,字段名2=字段值2...,字段名n=字段值n [where 条件表达式];
#注意:更新的数据可以是0-N条记录

说明:

update 数据库表名: 指定需要更新的数据库表

set 字段名=字段值: 修改指定的数据库表中字段的值

[where 条件表达式]: 修改满足条件的记录的字段值,可省略

不带条件记录更新

格式:
update 数据库表名 set 字段名1=字段值1,字段名2=字段值2...,字段名n=字段值n;  #表示修改表中所有记录

案例:

加入一个性别(sex varchar(2))字段,将sex的值都改为“男”

#在student表中增加字段sex
mysql> alter table student add sex varchar(2);
Query OK, 0 rows affected (0.24 秒)
#查看表结构
mysql> desc student;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | YES  |     | NULL    |       |
| sname    | varchar(20) | YES  |     | NULL    |       |
| birthday | date        | YES  |     | NULL    |       |
| sex      | varchar(2)  | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
4 行于数据集 (0.01 秒)
#修改student表中sex字段的值为'男'
mysql> update student set sex='男';
Query OK, 3 rows affected (0.09 秒)
#查看表中所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 1    | 林志颖 | 1974-10-18 | 男  |
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | NULL       | 男  |
+------+-----------+------------+------+
3 行于数据集 (0.01 秒)

带条件记录更新

格式:
update 数据库表名 set 字段名1=字段值1,字段名2=字段值2...,字段名n=字段值n [where 条件表达式];   #表示修改表中满足条件的记录

案例:

修改id=3的记录,将sex改为’女’

#修改id为3记录中的sex改为'女'
mysql> update student set sex='女' where id=3;
Query OK, 1 rows affected (0.01 秒)
#查看表中所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 1    | 林志颖 | 1974-10-18 | 男  |
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | NULL       | 女  |
+------+-----------+------------+------+
3 行于数据集 (0.01 秒)

修改id=3的记录,将sex改为’女’,birthday改为1980-11-08

#修改id为3记录中的sex改为'女',birthday改为1980-11-08
mysql> update student set sex='女',birthday='1980-11-08' where id=3;
Query OK, 1 rows affected (0.11 秒)
#查看表中所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 1    | 林志颖 | 1974-10-18 | 男  |
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | 1980-11-08 | 女  |
+------+-----------+------------+------+
3 行于数据集 (0.01 秒)

2.2、删除记录

格式:
delete from 数据库表名 [where 条件表达式];

说明:

delete from 数据库表名: 指定删除记录的表

[where 条件表达式]: 删除满足条件的记录的字段值,可省略

带条件删除记录

格式:
delete from 数据库表名 [where 条件表达式]; #删除满足条件的记录

案例:

删除id为1的记录

#删除id=1的记录
mysql> delete from student where id=1;
Query OK, 1 rows affected (0.08 秒)
#查看所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | 1980-11-08 | 女  |
+------+-----------+------------+------+
2 行于数据集 (0.02 秒)

不带条件删除记录

格式:
delete from 数据库表名;    #删除表中所有的记录
或
truncate table 数据库表名;   #删除表中所有的记录

案例:

删除表中所有记录

#删除所有记录
mysql> delete from student;
Query OK, 2 rows affected (0.08 秒)
#查看所有记录
mysql> select * from student;
空的数据集 (0.01 秒)
#删除所有记录
mysql> truncate table student;
Query OK, 0 rows affected (0.08 秒)
#查看所有记录
mysql> select * from student;
空的数据集 (0.01 秒)

注意:

truncate删除的是表的结构,再创建一张表;delete删除的是表的记录;


✨ 这就是今天要分享给大家的全部内容了,我们下期再见!😊
🏠 我在CSDN等你哦!我的主页😍

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28225.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用CloudCompare软件拟合点云中的圆柱体

用CloudCompare软件拟合点云中的圆柱体 软件下载 点击下面的链接,进入下载页面: 下载页面 然后根据需要选择下载合适的软件版本。 一般选择windows installer版,如图所示: 下载完成后,安装并打开软件。软件的默认语…

解决 kali 中使用 vulhub 拉取不到镜像问题

由于默认情况下,访问的镜像是国外的,而从 2023 年开始,docker 的镜像网站就一直访问不了,所以我们可以把镜像地址改成国内的阿里云镜像地址。 1、在 cd /etc/docker/目录下创建或修改daemon.json文件 sudo touch daemon.json 2、在…

docker 简单在线安装教程

1、配置阿里镜像源 wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo 2、指定版本安装docker 本次制定安装 docker 服务版本、客户端版本都为: 19.03.14-3.el7 yum -y install docker-ce-19.03.14-3.e…

ffmpeg实现视频播放 ----------- Javacv

什么是Javacv和FFmpeg? Javacv是一个专门为Java开发人员提供的计算机视觉库,它基于FFmpeg和Opencv库,提供了许多用于处理图 像、视频和音频的功能。FFmpeg是一个开源的音视频处理工具集,它提供了用于编码、解码、转换和播放音视频…

Unity Meta Quest 开发:与 Unity 的 UI 系统进行交互

文章目录 📕教程说明📕教程内容概括📕添加玩家物体📕添加 Canvas 物体和 EventSystem 物体📕修改 Canvas 组件的 Render Mode📕在 Canvas 上搭建 UI 面板📕利用 Interaction SDK 的 Quick Actio…

英伟达与斯坦福携手,打造未来全息XR眼镜:头带时代的终结

在XR(扩展现实)技术的演进过程中,一个显著的挑战在于如何平衡设备的便携性与视觉体验。传统的XR设备由于需要厚重的头带固定光学器件和显示器,不仅增加了体积,还为用户带来了社交上的不便。然而,随着英伟达与斯坦福大学戈登韦茨斯坦教授领导的研究团队的合作,这一难题似…

python包管理器--- pip、conda、mamba的比较

1 pip 1.1 简介 pip是一个 Python 的包(Package)管理工具,用于从 PyPI 安装和管理 Python 标准库之外的其他包(第三方包)。从 Python 3.4 起,pip 已经成为 Python 安装程序的一部分,也是官方标准…

IO流及字符集

IO流 作用: 用于读写文件中的数据 分类: 图来自黑马程序员网课 纯文本文件:Windows自带的记事本打开能读懂的文件,word excel不是纯文本文件 图来自黑马程序员网课 FileOutputStream: 操作本地文件的字节输出流,可…

板凳------56.Linux/Unix 系统编程手册(下) -- SOCKET 介绍

56.1.概述 socket 是一种IPC方法,允许位于同一主机或使用网络连接起来的不同主机上的应用程序之间交换数据。 UNIX 允许位于同一主机系统上的应用程序之间通信 Internet domain IPv4 and IPV6 // socket 通信方式 1.各个应用程序创建一个socket,socket是…

vue3:实现图片放大浏览功能组件

两种实现方式&#xff1a; 1.将原本的盒子与img标签放大至全屏浏览。 2.新建一个div和img标签进行全屏浏览。这样不会改变布局。 第一种&#xff1a; 效果&#xff1a; 组件代码&#xff1a; <template><div :class"isScreen ? fullImg : norImg">…

Confluence是否免费?你需要知道的都在这里!

根据Atlassian官方信息&#xff0c;可以确定的是 Confluence 并不免费&#xff0c;但为10人以下团队提供了免费版本。免费版可以使用不限量的页面、空间&#xff0c;但只有2GB的存储空间和3个活动白板。但国内有不少公司通过使用破解版的方式来免费使用Cofluence。下面本文将详…

【什么!Grok记录被打破了】坏消息不是Meta的 llama3 400,好消息是Nvidia发布的Nemotron-4 340B且支持开源

Nvidia 发布了开创性的开放模型系列 “Nemotron-4 340B”&#xff0c;再次巩固了其作为人工智能创新领域无可争议的领导者的地位。这一发展标志着人工智能行业的一个重要里程碑&#xff0c;因为它使各行各业的企业能够创建功能强大的特定领域 LLM&#xff0c;而无需大量昂贵的真…

深入分析 Android BroadcastReceiver (三)

文章目录 深入分析 Android BroadcastReceiver (三)1. 广播消息的优缺点及使用场景1.1 优点1.2 缺点 2. 广播的使用场景及代码示例2.1. 系统广播示例&#xff1a;监听网络状态变化 2.2. 自定义广播示例&#xff1a;发送自定义广播 2.3. 有序广播示例&#xff1a;有序广播 2.4. …

线代知识点总结

目录 一.初等行/列变换 1.计算行列式时&#xff0c;行列变换都可 2.求矩阵的秩时&#xff0c;行列变换都可 3.解线性方程组时&#xff0c;仅能使用初等行变换 4.判定解的情况&#xff0c;单纯求r(A),r(A,b)的过程行列变换都可 5.求向量组极大无关组、线性表出关系&#x…

汽车级TPSI2140QDWQRQ1隔离式固态继电器,TMUX6136PWR、TMUX1109PWR、TMUX1133PWR模拟开关与多路复用器(参数)

1、TPSI2140-Q1 是一款隔离式固态继电器&#xff0c;专为高电压汽车和工业应用而设计。 TPSI2140-Q1 与 TI 具有高可靠性的电容隔离技术和内部背对背 MOSFET 整合在一起&#xff0c;形成了一款完全集成式解决方案&#xff0c;无需次级侧电源。 该器件的初级侧仅由 9mA 的输入电…

线程介绍及其Java如何用Thread 类创建线程和操作线程方法

目录 一、进程和线程1.1 进程特征 2.2 线程特征 2.3 区别 二、利用Thread类创建线程2.1 通过创建Thread子类&#xff0c;重写run()方法2.2 通过实现Runnable接口&#xff0c;重写run()方法2.3. Callable接口 FutureTask 创建线程2.3 三种方法区别1. 通过创建Thread子类&#x…

SQL深度解析:掌握这些技巧,让你的数据库查询如虎添翼!

前言 随着大数据时代的来临&#xff0c;数据库的角色愈发重要。SQL作为使用最为广泛的数据查询语言&#xff0c;其深度解析与优化对于数据密集型应用来说至关重要。掌握高级SQL技巧不仅可以提升开发效率&#xff0c;还能显著提高数据查询的性能和灵活性。本文将探讨一些关键的S…

修改SubVI的LabVIEW默认搜索路径

在启动顶级VI后&#xff0c;LabVIEW可能会遇到找不到subVI的情况。这通常是由于subVI的路径发生了变化或没有被正确配置。 LabVIEW默认搜索路径 默认情况下&#xff0c;LabVIEW会按以下顺序搜索文件位置&#xff08;*表示LabVIEW将搜索子目录&#xff09;&#xff1a; <t…

如何从印刷体的图片中把手写体部分统统去掉?--免费途径

AI图像处理技术 我是从国外某个网站上找到在线AI免费credit的处理方式的。国内的基本没有全功能试用、或者即使收费也不好用。 国内的差距主要是&#xff1a;1、对图片分辨率和大小有更多限制&#xff0c;即使收费用户也是&#xff1b;2、需要安装app之类&#xff0c;然后连线…

MongoDB使用$addToSet向数组中添加元素

学习mongodb&#xff0c;体会mongodb的每一个使用细节&#xff0c;欢迎阅读威赞的文章。这是威赞发布的第66篇mongodb技术文章&#xff0c;欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题&#xff0c;欢迎在文章下面点个赞&#xff0c;或者关…