MySQL数据库 【增删改查】

news2025/1/9 14:29:44

目录

一、新增

 指定列插入

一次插入多个数据

二、查询

1、全列查询

2、指定列查询 

3、查询字段为表达式

4、查询的时候给列名/表达式 指定别名

5、查询时去重

6、排序查询

7、条件查询

8、模糊查询

9、空值查询

10、分页查询 

三、修改   

四、删除


 SQL 最核心的操作就是增删改查,作为一个后端开发,我们在未来的工作中最常遇见的场景也就是增删改查(CRUD)

一、新增

语法:

insert into 表名 values(值,值....)

新增也就是网数据表中插入一条记录,语法中此处列出的这些值的数目和类型要和表的列相匹配。

我们现在先在java这个数据库中创建一个student表:

 

然后再在这个表中插入数据

 

 此时颜色对应的部分也就是我们前面所指的值和值对应

这里我们要注意一点:

SQL 中表示字符串使用 ' 或者 " 都行

也就是说在SQL中并没有“字符”类型

大部分没有字符类型的编程语言,都是允许 单引号 和 双引号 来表示字符串并且单双引号效果通常是等价的

 此外,如果我们要想能够正确的插入中文,必须保证在创建数据库的时候,指定 charset utf8

这样才能保证插入中文的时候不会进行报错。

 指定列插入

在进行数据的插入的时候,我们也可以对单独的某个列进行插入

语法;

insert into 表名(列名) values (值);

 使用括号( )来标识目前要针对哪些列进行插入,多个列名之间可以使用 ,  进行分割

后续values 里的列必须要和当前 ( ) 中的列的个数和类型都匹配


一次插入多个数据

在values 后面,可以有多个和( ),多个 ( ) 之间用 , 分割,每一组 ( )就是一条记录(也就是一行)

那么 问题来了,我们一次插入 3 条记录和分 3 次插入一条记录有什么区别呢?

我们要时刻牢记: MySql 是一个客户端服务器结构的程序!!!

那么哪种更好呢?

我们要知道:每一次网络交互,都是有一定的成本的!!

而第一种的成本更低。因此第一种是更优的选择。 


二、查询

查询语句能让我们看到表中包含的数据内容

1、全列查询

select *from 表名;

这个操作,就是查询出当前数据库中所有的行和所有的列

其中,* 是通配符,可以把它理解成斗地主中的“癞子”,* 就能够代指任意的列

 那么上图就是全列查询的全部效果

那么我们前面也说了,MySQL是一个客户端服务器结构的程序,全列查询可以用下图来表示

select * 是一个非常危险的操作!!!

如果,当前select* 查询的这个表,里面的的数据非常非常多(比如,几十亿条....),这样的操作就会导致这个服务器一瞬间,硬盘的带宽和网卡的带宽都被吃满了!!!

这就会使服务器无法给外面的普通用户提供服务了此时服务器就像 “卡死” 了一样


2、指定列查询 

手动指定要查询到额某一列或者某几列 ,服务器返回的额结果就只包含想要的数据

语法:

select 列名,列名... from 表名;

我们现在重新创建一个表,将其命名为exam_result

先对其进行一次全列查询

 

再对其进行指定列查询,操作结果如下:

 数据库的增删改查,都是比较慢的,也是比较吃硬件资源的,因此我们尽量能省则省


3、查询字段为表达式

查询的同时可以进行计算

例如我们要查询所有同学,数学成绩加10分之后的效果,可以这样写:

 此处,我们看到的客户端中显示的结果,其实是一个“临时表”,select 操作不管怎么写,都不会影响到数据库服务器硬盘上存储的原始数据

SQL中四则运算只能针对数字进行!!!

但是也可以将两个列的数值,或者多个列之间的数值进行计算

 这时,我们会发现,此时查询结果中临时表的列名和咱们当前表达式是一致的,这就导致了如果查询的表达式非常的复杂,就会导致列名也非常的复杂,不利于用户来阅读


4、查询的时候给列名/表达式 指定别名

语法:

select 列名 as 别名 from 表名;

此时,别名会最终显示在查询结果的临时表中

另外,as 这个关键字是可以省略的,但是我们不建议省略

最终的效果如下:

SQL中。列名和表名都是可以起别名的,取名的方式,都是用as  


5、查询时去重

把重复的行去掉,只保留一份

语法:

select distinct 列名 from 表名;

我们现在先查询一下math 这一列的数组

此时会发现,98.0这个数值有两个,当我们现在进行查询时去重的操作之后,临时表中便只会显示一个98.0了

 同样的,distinct 后面的列名,也可以是多个

当指定多个列的时候,则要求必须所有列的值都相同,才算 “重复”


6、排序查询

针对查询到的结果进行排序

还是那句话,MySql 是一个客户端-服务器结构的程序因此这里的排序也只是针对临时表进行的,对于数据库服务器上原始的数据并没有任何顺序上的影响

语法:

select 列名 from 表名 order by 列名;

排序的时候,依据order by 后面的那个列进行排序

举个例子,这个是是不排序之前临时表的顺序:

按照英语成绩排序后升序排序的结果是这样的:

 

 如果想要得到降序排序,则只需要在最后加上 desc 即可

 如果 SQL 中,没有指定 order by,此时我们的代码中,就不应该依赖结果集合(临时表)的顺序!!!

MySQL并不承诺,这个不带order by 的查询结果是有一定的顺序的

order by 后面是可以接多个列的

这个顺序表示: 先针对数学进行排序,如果数学相同,再根据英语进行排序


7、条件查询

指定一个筛选条件,把符合条件的结果保留下来,不符合的就剔除掉

关系运算符:

注意事项: 

有些列是可以不填的(不填就相当于是NULL)

NULL参与各种运算,运算的结果还是NULL

NULL = NULL             结果是false 

NULL <=> NULL         结果是true  

  逻辑运算符:

 示例1:查询英语不及格的同学的英语成绩

 注意理解查询语句执行的过程:

1、服务器需要先遍历表中的每一个记录

2、针对当前记录,带入条件,看是否成立

3、如果条件成立,则这一条记录加入结果集,并返回给客户端

4、如果条件不成立,则这一条记录跳过

条件比较的时候,并不只是使用列名和常量比较,也可以使用列名和其它列名比较,例如

示例2:查询语文成绩大于英语成绩的同学

 此外,条件查询也可以结合一些更复杂的表达式

示例3:查询总分小于200的同学

 注意:当我们在条件中,尝试使用别名的时候,这个别名是不能被正确识别出来的!!!

MySQL 的 where 条件中,无法使用 列 的别名!!!


8、模糊查询

MySQL中提供的模糊查询,是相对比较简单的 :like

MySQL中提供了两个通配符:

%  匹配 0 个 或者 任意个 字符

_   匹配 1 个任意字符

 示例:查询姓孙的同学

 示例:查询名字以孙结尾的同学

其实,MySQL进行 like 模糊查询是一个比较低效的操作,尤其是针对一些比较长的字符串

因此我们使用模糊查询的时候要慎重 


9、空值查询

除了之前讲过的 =  和 <=> 的区别之外,它们在使用方法上还有别的不同

<=> 可以用于两个列之间的比较


10、分页查询 

分页查询:limit 

针对查询出来的结果,进行 截取,取出其中的一部分

                                                                                                                                                                                                                                                                                                                              这个操作中 limit 4 的意思是,一次查询,最多查询到4条记录

那么如果我们想查询到下一页的记录,则应该这样写:

                                                                                                                                                            其中,limit 约束了结果中最多包含几条记录  ,offset 描述了当前的结果从哪一条开始算,也可以当做从下标为4 的记录开始获取


三、修改   

语法:

update 表名 set 列名 = 值 where 条件;

  进行修改的时候要明确一些重要信息:

1、改哪个表

2、改这个表的哪个列 / 哪个行,改成什么

3、改这个表的哪些行                                                                                                               

 示例:将孙悟空的数学成绩改成80分

我们可以看到,目前孙悟空的数学成绩是78分

 那么接下来,我们对其进行 update 操作

注意:math = 80 此处的等号是赋值的意思,不再是比较相等了 

 经过上述的修改之后,我们再查询孙悟空的成绩

此时,其数学成绩已经成功被修改成了80

注意:此处的修改是修改MySQL 服务器保存在硬盘上的数据(持久生效的) 

 此外,update 也可以一次操作修改多个列

示例:将曹孟德的数学成绩变更为 60 分,语文成绩变更为 70 分

曹孟德本来的成绩如下:

 然后使用update 对其两列成绩进行修改

 结果如下:

此外,修改操作也可以搭配 order by 这样的排序操作 

示例:把总成绩倒数的3位同学,数学成绩加上30分

我们现在可以看到,总成绩倒数三名的同学是这三位:

现在,我们要对它们的数学成绩进行加三十分的操作

 但是这个时候发生了报错,这是因为刘玄德的数学成绩此时是85,而此处设定的成绩是3位有效数字,如果再加30,那么就是四位有效数字了,所以这里我们选择只加10分

 然后我们便会发现刚才倒数的三位同学的数学成绩都加上了10分

由此得知: select 中支持的条件,排序,分页对于update来说,是同样生效的

update 可以理解成: 先查询,再修改

注意:如果我们在 update 操作的时候,没有加其它条件,会将所有的行都进行修改!!!


四、删除

delete 直接删除符合条件的行

语法:

delete from 表名 where 条件;

示例:删除孙悟空的考试成绩

删除前:

 

删除操作: 

删除后:

注意:删除是按照行来进行删除的,我们无法删除某些列 

如果先要删除列,可以通过update 把指定条件的行的指定列设为null

同样的,如果在delete 的时候,没有指定数据,就会将整张表的数据都删除掉

效果和删除表差不多,但还是略有不同

delete from 删除之后,表还在,但是表里面的数据没有了

drop table 删除之后,表以及表里面的数据都没有了 

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

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

相关文章

python如何知道你的导包在哪/site-package在哪/anaconda中的模块文件在哪

参考: https://stackoverflow.com/questions/31003994/where-is-site-packages-located-in-a-conda-environment anaconda虚拟环境中的site-package在如下目录&#xff0c;/opt/conda/envs/env_cp37_STAGATE_TF/lib/python3.7/site-packages/。 基于寻找你导包的物理位置在哪…

婚纱照主题定义

文章目录 前言关于我们听我们说关于风格&#xff1a;1、主纱&#xff08;内&#xff09;2、工笔画&#xff08;内&#xff09;3、个性潮拍 &#xff08;内&#xff09;4、森系&#xff08;外&#xff09;5、园林&#xff08;外&#xff09;写在最后 前言 非常感谢在今生有约婚…

doris恢复库恢复表

今天眼疾手快 不小心删了公司生产环境的表 而且碰巧这个数据没有备份的 当时哥们就呆住 还好doris升级过1.2 刚推出了恢复数据的功能~~~~~这里给老天爷磕一个了~~~~~~ 数据删除恢复 Doris为了避免误操作造成的灾难&#xff0c;支持对误删除的数据库/表/分区进行数据恢复&…

什么是DIN连接器 DIN连接器的应用

一、什么是DIN连接器 DIN连接器是一种遵循德国国家标准化组织制定的连接器标准的电子连接器。它采用圆形外观和标准化的接口设计&#xff0c;以确保与其他符合DIN标准的设备和连接器的兼容性。DIN连接器通常由插头和插座两部分组成&#xff0c;通过插拔操作实现电路的连接和断开…

面试时被问到职业规划,怎样回答才最加分?

很多人被问到「职业规划」这个问题的时候&#xff0c;都会很………纠结&#xff1a; 表现得太踏实苦干了&#xff0c;可能会让人觉得没有什么进取心。 职业目标描述得太明确&#xff0c;又会被质疑太在意外部激励而缺乏内部动机。 感觉怎么说都会错&#xff0c;说多一句都是…

Java 中 synchronized 的优化操作:锁升级、锁消除、锁粗化

由 并发编程中常见的锁策略 总结可知&#xff0c;synchronized 具有以下几个特性&#xff1a; 开始时是乐观锁&#xff0c;如果锁冲突频繁&#xff0c;就转换为悲观锁。开始是轻量级锁实现&#xff0c;如果锁被持有的时间较长&#xff0c;就转换成重量级锁。实现轻量级锁时&am…

预处理详解(二)---#define 定义宏 + 宏的使用 + 宏和函数的区别

文章目录 #define 定义标识符#define 定义宏#define 的替换规则带副作用的宏参数宏和函数的区别#undef 的作用冷门知识点&#xff1a;#与## #define 定义标识符 #define定义标识符的格式如下&#xff1a; #define MAX 100 #define reg register//懒人觉得register太长了这些被…

Virus Total 曝数据泄露大事件:涉及多国情报部门

The Hacker News 网站披露&#xff0c;可疑文件和病毒在线检测平台 VirusTotal 曝出数据泄露事故&#xff0c;一名员工无意中将部分 VirusTotal 注册客户的姓名、电子邮件地址等敏感数据信息上传到了恶意软件扫描平台&#xff0c;此举导致约 5600 名用户数据泄露。 据悉&#x…

Display

Pipeline Dataloader和后面网络训练是解耦的&#xff0c;Dataloader负责把数据读出来变成tensor&#xff0c;网络&#xff08;继承nn.Module父类&#xff09;负责把这tensor算成最后的输出。在网络传播的过程中&#xff0c;hook记录保留中间数据&#xff0c;用于display作图。…

CSS——基础知识及使用

CSS 是什么 CSS是层叠样式表 (Cascading Style Sheets)的简写.CSS 能够对网页中元素位置的排版进行像素级精确控制, 实现美化页面的效果. 能够做到页面的样式和结构分离。 基本语法规范 选择器 { 一条/N条声明 } 选择器决定针对谁修改 (找谁)声明决定修改啥. (干啥)声明的…

PP速度模式应用

应用场景要求&#xff1a; 电机在变化的负载下&#xff0c;保持设定的速度时&#xff0c;需要使用速度模式。 在速度模式下&#xff0c;电机速度由发送到电机的电压控制。但是要改变电机的速度&#xff08;加速或减速&#xff09;需要增加或减小电机转矩&#xff0c;因此在速度…

Stable Diffusion - 编辑生成 (OpenPose Editor) 相同人物姿势的图像

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/131818943 OpenPose Editor 是 Stable Diffusion 的扩展插件&#xff0c;可以自定义人物的姿势和表情&#xff0c;以及生成深度、法线和边缘图等信…

rt-thread rtc设备驱动开发

基于pico rtc设备驱动开发 I/O设备框架RTC设备功能配置——启用Soft RTC功能配置——启用NTP时间自动同步功能配置——启用硬件RTC RT-Thread 的 RTC &#xff08;实时时钟&#xff09;设备为操作系统的时间系统提供了基础服务。应用层对于 RTC 设备一般不存在直接调用的 API &…

three.js学习

前言&#xff1a; three.js基本使用没问下&#xff0c;下面进入自定义图形 效果展示 实现 使用BufferGeometry()自定义 <script setup lang"ts"> import { ref, onMounted } from vue import * as THREE from three // 导入轨道控制器 import { OrbitContro…

Java对象深拷贝、浅拷贝之枚举类型

问题&#xff1a;为什么属于引用类型的enum不会有深拷贝浅拷贝的问题&#xff1f; 解释&#xff1a; 在Java中&#xff0c;枚举类型是一种特殊的类类型。每个枚举值都是该枚举类型的一个实例&#xff0c;并且这些实例在枚举类型被初始化时就已经被创建。这些实例在程序的整个…

2023年7月18日,File类,IO流,线程

File类 1. 概述 File&#xff0c;是文件和目录路径的抽象表示 File只关注文件本身的信息&#xff0c;而不能操作文件里的内容 。如果需要读取或写入文件内容&#xff0c;必须使用IO流来完成。 在Java中&#xff0c;java.io.File 类用于表示文件或目录的抽象路径名。它提供了一…

elementUI el-radio 无法点击的问题

<el-form-item label"B端客户类型" prop"user_type"><template slot"label"><span>B端客户类型</span><el-tooltip effect"dark" placement"top" content"B端大客户账期有效,只有设置该类型…

数据结构双向链表,实现增删改查

一、双向链表的描述 在单链表中&#xff0c;查找直接后继结点的执行时间为O(1)&#xff0c;而查找直接前驱的执行时间为O(n)。为克服单链表这种单向性的缺点&#xff0c;可以用双向链表。 在双向链表的结点中有两个指针域&#xff0c;一个指向直接后继&#xff0c;另一个指向直…

AJAX: 事件循环(举例细论)

概念&#xff1a;执行任务和收集异步任务&#xff0c;在调用栈空闲时&#xff0c;反复调用任务队列里回调函数的一种执行机制 原因&#xff1a;JavaScript 是单线程的&#xff0c;为了不阻塞 JS 引擎&#xff0c;设计执行代码的模型 JS内代码如何执行&#xff1a; 执行同步代…

暴雪娱乐遭DDoS攻击,《暗黑破坏神》等多款游戏受影响

6月25日上午11点&#xff0c;有游戏玩家反应Blizzard Battle.net无法登入、连线缓慢及网站问题&#xff0c;暴雪也证实其电玩平台遭到DDoS攻击。 暴雪娱乐的 Battle.net在线服务遭到分布式拒绝服务&#xff08;DDoS&#xff09;攻击&#xff0c;导致玩家无法正常登录游戏或游戏…