Linux下学【MySQL】表中插入和查询的进阶操作(配实操图和SQL语句通俗易懂)
绪论
每日激励:挫折是会让我们变得越来越强大的重点是我们敢于积极的面对它。—Jack叔叔
绪论:
本章是表操作的进阶篇章(没看过入门的这里是传送门,本章将带你进阶的去学习表的插入insert和查找select,本质也就是学他们后面所带的一些附加条件(具体请看目录),通过这些条件去更好的插入和查找你所需要的数据。本章是上篇(全文8000字),下篇将写道修改和删除,将快速更新敬请期待。
————————
早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。
表的增删查改
CURD是一个数据库技术中的缩写词,一般的项目开发的各种参数的基本功能都是CURD。作用是用于处理数据的基本原子操作。(源百度百科)
CURD:
- Create(创建)、
- Retrieve(读取)、
- Update(更新)、
- Delete(删除)
1. Create插入数据(Insert细节操作)
INSERT [INTO] table_name [(column [, column] ...)] VALUES (value_list) [, (value_list)] ...
直接通过实例来学习:
先创建一个学生表(后续在学生表上进行操作)

1.1 单行数据插入:

- 主要需要理解的结构:
(需要插入的属性列) values(对应的值)
insert into students (插入中:into可省略,students就是要插入的表名) - 当values右边列属性不写,就是一次性插入所有属性(全列插入)

1.2 多行插入:
也很简单直接在插入的数据 用逗号分隔 连续插入(具体如下图)

同样能指定列插入,这里就不过诉了。
1.3 冲突时同步更新:
当插入数据时可能会有主键、唯一键冲突…等情况,假如直接插入会直接报错。
那么现在可以通过添加一些语法,让当有冲突(即已存在该数据)时,对冲突进行处理,让即使有问题也能插入,而不是直接报错。
语法:
on duplicate key update
例如:
下述插入许攸的情况,若直接插入,因为主机冲突的情况无法直接插入新的值。
那么我们使用(原SQL)on duplicate key update (更新SQL)这样就能插入,并且修改即使存在也会将他修改为新的

下面再看具体语法:
在插入语句后面添加:
INSERT ...... ON DUPLICATE KEY UPDATE
column = value [, column = value] ...-- 0 row affected: 表中有冲突数据,但冲突数据的值和 update 的值相等
-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,并且数据已经被更新select ROW_COUNT()-- 获取受影响函数
1.4 冲突时同步替换:
语法:
-- 主键 或者 唯一键 没有冲突,则直接插入;
-- 主键 或者 唯一键 如果冲突,则删除后再插入
replace into students (sn, name) VALUES (20001, '曹阿瞒');
Query OK, 2 rows affected (0.00 sec)-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,删除后重新插入
实例:
当插入冲突时,会直接进行替换(此时就会显示2行影响行数),注意此处是删除后再插入(id会改变)
具体如下图:

2. Retireve读取数据(Select细节操作)
语法:
SELECT
[DISTINCT] {* | {column [, column] ...}
[FROM table_name]
[WHERE ...]
[ORDER BY column [ASC | DESC], ...]
LIMIT ...
同样是用实例来学习:
创建表并插入数据:

2.1 全列查询
通常情况下不建议使用 * 进行全列查询
1. 查询的列越多,意味着需要传输的数据量越大;
2. 可能会影响到索引的使用。(索引待后面课程讲解)
语法:
SELECT * FROM exam_result;
之前讲写了就不过诉了!
2.2 指定列查询
-- 指定列的顺序不需要按定义表的顺序来
和插入时类似在前面加上要查询的列名称,不同的是此时变成了FROM
SELECT id, name, english FROM exam_result;

2.3 查询字段为表达式
在select 后可以添加表达式,将会在查询结果中带上表达式结果。
表达式不包含字段时:
SELECT id, name, 10 FROM exam_result;
发现将会直接打印10(其实代表的是该表达式的计算结果)

查询有字段的表达式时:
并且还能通过as进行重命名:
如求一行中的成绩总和

其中as可以省略:

2.4 结果去重 DISTINCT
SELECT DISTINCT math FROM exam_result
很简单就是将查询到的重复数据只见一行。
2.5 where条件
比较运算符:
| 运算符 | 说明 |
|---|---|
| > , >=, <, <= | 大于,大于等于,小于,小于等于 |
| = | 等于,只能用于数值的比较,NULL 不安全(不能比较),例如 NULL = NULL 的结果是 NULL |
| <=> | 等于,NULL 安全,例如 NULL <=> NULL 的结果是 TRUE(1) |
| !=, <> | 不等于NULL 不安全 |
| BETWEEN a0 AND a1 | 范围匹配,[a0, a1],如果 a0 <= value <= a1,返回 TRUE(1) |
| IN (option, …) | 如果是 option 中的任意一个,返回 TRUE(1) |
| IS NULL | 是 NULL |
| IS NOT NULL | 不是 NULL |
| LIKE 模糊匹配 | % 表示任意多个(包括 0 个)任意字符;_ 表示任意一个字符 |
附:
=号,不能用于比较NULL值,比较NULL值需要使用<=>
具体如下:
当直接用 = 进行比较时比较后会为NULL、的使用<=>这样就能正常比较
逻辑运算符:
| 运算符 | 说明 |
|---|---|
| AND | 多个条件必须都为 TRUE(1),结果才是 TRUE(1) |
| OR | 任意一个条件为 TRUE(1), 结果为 TRUE(1) |
| NOT | 条件为 TRUE(1),结果为 FALSE(0 |
实例:
比较运算符
- 找英语成绩不合格的人:

between运算符的使用
- 语文成绩在 80 ~ 90 分的同学和成绩

上述和使用between a1 and a2 (a1 ~ a2)一样,但between更方便。

in运算符的使用
in:如果是 option 中的任意一个,返回 TRUE(1)
- 取出数学成绩 58 或 59 或 98或99 的同学和成绩
可以直接使用 or

也可以使用 math in(58,59,…)

like模糊查询
使用 like:
%表示模糊查询后面任意多个(包括 0 个)任意字符;_表示模糊查询后面任意一个字符
- 查询孙某某(使用%,因为不确定其后面有几个字)

若写成_(就只能查孙某):

where后面能使用表达式(和字段)
- 语文好于英语成绩

- 总分在200以下的同学

注意其中不能在where后面使用as重命名的变量,这是因为在select中是where是先执行的,然后才到筛选列,所以也就是as还未定义,无法使用。
具体执行顺序:- from(先找表)
- where(筛选条件),
- select(查找的列属性)
所以因为先where,才到列属性,所以重命名是不能使用的(列属性处还未被定义,就不能在where中使用了)
not运算符
-
寻找语文成绩大于80且不姓孙

-
是孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80
- 要么是孙某
- 否则:要求总成绩 > 200 and 语文 < 数学 and 英语 > 80
- 可先把后面一长串的内容先写 然后 再去加上前面的孙某

NULL的查询
重新新建一个表test:

- 查询NULL

- 查询不为空

- NULL不参与比较运算,要比较只能使用<=> 、<>

2.6 order by语句(结果排序)
- ASC 为升序(Ascending)(从小到大)
- DESC 为降序(Descending)(从大到小)
- 默认为 ASC
- 没有order by子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序
语法:
SELECT ... FROM table_name [WHERE ...]
ORDER BY column [ASC|DESC], [...];
实操:
ASC升序:
- 按数学成绩升序显示

- 降序desc

NULL值在排序中,默认设置为比任何值都要小

多字段排序,排序优先级随书写顺序
具体理解如下:
查询同学各门成绩,依次按 数学降序,英语降序,语文升序的方式显示

上图中先按数学降序(数学写在英语前面),当数学相等时才按英语降序,最后才考虑写到最后的语文
建议就是向上图一样,将排序的 方式全部列全出来,不要去使用MySQL默认的情况(无法掌控)
order by默认升序

可以在order by 中使用前面的as别名

因为在order by中需要对数据进行排序,一定要先有适合的数据才排序(所以他是先执行前面的列属性筛选那么它就能排序)

2.7 limit的使用(筛选分页结果)
- 直接在select后面加上limit表示需要的行数(从开始到第n行)

- 当limit 还能从 指定位置开始,读取连续个数(pos,len)(并且注意:开始位置是从0开始的)
如下图:从第一个开始读,3个

- 在limit读取行数的前提下,还能通过offset设置开始的行数(同样是从0开始)

建议对未知表查询时,对limit限制为1,防止数据过大
limit的作用,类似于网页中常见的页面的1、2、3、4 。。。分页显示数据。
如下图:

limit的执行阶段会更加靠后,因为只有最后将所有数据都准备好了,才到最终的显示,而limit的本质功能也就是显示,所以将排到最后。
结合上面多个读取数据的方法实例:
获取班级第一(如下图):
SELECT name, (english + math + chinese) AS total
FROM exam_result
WHERE english + math + chinese > 200
ORDER BY total DESC
LIMIT 1;

本章完。预知后事如何,暂听下回分解。
如果有任何问题欢迎讨论哈!
如果觉得这篇文章对你有所帮助的话点点赞吧!
持续更新大量MySQL细致内容,早关注不迷路。
相关文章:
Linux下学【MySQL】表中插入和查询的进阶操作(配实操图和SQL语句通俗易懂)
绪论 每日激励:挫折是会让我们变得越来越强大的重点是我们敢于积极的面对它。—Jack叔叔 绪论: 本章是表操作的进阶篇章(没看过入门的这里是传送门,本章将带你进阶的去学习表的插入insert和查找select,本质也就是…...
从百度云网盘下载数据到矩池云网盘或者服务器内
本教程教大家如何快速将百度云网盘数据集或者模型代码文件下载到矩池云网盘或者服务器硬盘上。 本教程使用到了一个开源工具 BaiduPCS-Go,官方地址 : https://github.com/qjfoidnh/BaiduPCS-Go 这个工具可以实现“仿 Linux shell 文件处理命令的百度网…...
Vue.js 高级组件开发:抽象与高性能架构
Vue.js 高级组件开发:抽象与高性能架构 引言一、动态组件与依赖注入1. 动态组件场景 二、高可扩展性的抽象组件模式1. 设计思路2. 案例:抽象数据表组件 三、复杂场景下的异步操作管理1. 使用 Vue Composition API 管理异步逻辑 四、渲染优化与框架底层钩…...
Kubernetes 安装 Nginx以及配置自动补全
部署 Nginx : [rootk8s-master ~]# kubectl create deployment nginx --imagenginx:1.14-alpine deployment.apps/nginx created暴露端口: [rootk8s-master ~]# kubectl expose deployment nginx --port80 --typeNodePort service/nginx exposed查看服…...
CSS---实现盒元素div内input/textarea的focus状态时给父元素加属性!
注意兼容性,低版本浏览器无效 要实现当 textarea 文本框获得焦点时,自动给其父元素添加类名或样式,您可以使用 CSS 的 :focus-within 伪类选择器。这个选择器会在元素本身或其任何子元素获得焦点时应用样式。 示例代码 假设您有以下 HTML 结…...
jmeter设置tps、响应时间监测时间间隔
jmeter设置tps、响应时间监测时间间隔 思路: 1、设置tps和响应时间插件的采集时间间隔,然后运行jmeter脚本; 2、先按默认配置跑出jtl文件保存下来,再添加tps和响应时间插件,设置采集时间间隔后,导入jtl文件…...
WPSJS:让 WPS 办公与 JavaScript 完美联动
随着办公自动化需求的日益增长,WPS Office 推出了 WPSJS,这是一款强大的开发者工具,允许开发者通过 JavaScript 脚本与 WPS 办公软件进行互动。无论是在表格中自动填充数据、在文档中修改格式,还是在演示文稿中插入动态内容&#…...
深度学习与图像处理(国产深度学习框架——飞桨官方指定教材)
计算机视觉从小白到大师之路 《深度学习与图像处理(PaddlePaddle版)》这一本就够了 1.引言 随着人工智能技术的飞速发展,各行各业对深度学习、图像处理相关领域的人才需求日益迫切。本书旨在通过系统的理论讲解与丰富的实战案例࿰…...
taiwindcss
1.安装 npm install -D tailwindcss postcss autoprefixer npx tailwindcss init 这会创建一个 tailwind.config.js 文件。注意:一定通过px tailwindcss init方式创建 2.tailwind.config.js module.exports {content: [./index.html,./src/**/*.{js,ts,jsx,ts…...
信号的时域截断——频谱泄漏——光晕效应
在时域信号中,如果对一个包含不连续点的信号进行截断,即使用有限个样本点来表示原本无限长或更长的信号,那么在频域中这相当于对信号进行了乘以一个矩形窗的操作。这种操作会导致原信号频谱与矩形窗的频谱卷积,从而在频域中引入额…...
【Linux编程】TcpServer 类的设计与实现:构建高性能的 TCP 服务器(二)
TcpServer 类的设计与实现:构建高性能的 TCP 服务器 在现代网络编程中,构建一个高效、稳定的 TCP 服务器是许多网络应用的基础。本文将详细介绍一个基于 C 的 TcpServer 类的设计与实现,该类提供了创建 TCP 服务器、处理客户端连接、数据传输…...
Mono里运行C#脚本8—mono_image_storage_open打开EXE文件
Mono里运行C#脚本8—mono_image_storage_open打开EXE文件 前面分析哈希表的实现,以及文件打开的底层函数,还有保存到HASH表里的数据结构。 static MonoImageStorage * mono_image_storage_open (const char *fname) { char *key = NULL; key = mono_path_resolve_symlinks…...
XMLHttpRequest的基础知识
get请求 const xml new XMLHttpRequest(); xml.open("GET", "https://jsonplaceholder.typicode.com/todos/1", true); xml.onreadystatechange function () {if (xml.readyState 4 && xml.status 200) {console.log(xml.responseText);} }…...
力扣矩阵-算法模版总结
lc-73.矩阵置零-(时隔14天)-12.27 思路:(23min22s) 1.直接遍历遇0将行列设0肯定不行,会影响后续判断,题目又要求原地算法,那么进一步考虑是否可以将元素为0,其行列需要设为0的位置给存储下来,最后再遍历根据…...
如何在短时间内读懂复杂的英文文献?
当我们拿起一篇文献开始阅读时,就像是打开了一扇通往未知世界的大门。但别急着一头扎进去,咱们得像个侦探一样,带着疑问去探险。毕竟,知识的海洋深不可测,不带点“装备”怎么行?今天就聊聊,平时…...
基于aspose.words组件的word bytes转pdf bytes,去除水印和解决linux中文乱码问题
详情见 https://preferdoor.top/archives/ji-yu-aspose.wordszu-jian-de-word-byteszhuan-pdf-bytes...
Bert中文文本分类
这是一个经典的文本分类问题,使用google的预训练模型BERT中文版bert-base-chinese来做中文文本分类。可以先在Huggingface上下载预训练模型备用。https://huggingface.co/google-bert/bert-base-chinese/tree/main 我使用的训练环境是 pip install torch2.0.0; pi…...
【深度学习】Java DL4J基于 CNN 构建车辆识别与跟踪模型
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
【C#】C#打印当前时间以及TimeSpan()介绍
1. C#打印当前时间 string currentDate DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");Console.WriteLine(currentDate);2. TimeSpan()介绍 TimeSpan(long ticks)的单位是100ns //500ms new TimeSpan(10*1000*500);参考: C#-TimeSpan-计算时间差...
【Linux 网络 (五)】Tcp/Udp协议
Linux 网络 一前言二、Udp协议1)、Udp协议特点2)、Udp协议格式3)、Udp报文封装和解包过程4)、UDP的缓冲区 三、TCP协议1)、TCP协议特点2)、TCP协议格式1、4位首部长度、源端口、目的端口2、16位窗口大小3、…...
【kafka】Golang实现分布式Masscan任务调度系统
要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...
k8s从入门到放弃之Ingress七层负载
k8s从入门到放弃之Ingress七层负载 在Kubernetes(简称K8s)中,Ingress是一个API对象,它允许你定义如何从集群外部访问集群内部的服务。Ingress可以提供负载均衡、SSL终结和基于名称的虚拟主机等功能。通过Ingress,你可…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...
Android第十三次面试总结(四大 组件基础)
Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: onCreate() 调用时机:Activity 首次创建时调用。…...
Qt 事件处理中 return 的深入解析
Qt 事件处理中 return 的深入解析 在 Qt 事件处理中,return 语句的使用是另一个关键概念,它与 event->accept()/event->ignore() 密切相关但作用不同。让我们详细分析一下它们之间的关系和工作原理。 核心区别:不同层级的事件处理 方…...
什么是VR全景技术
VR全景技术,全称为虚拟现实全景技术,是通过计算机图像模拟生成三维空间中的虚拟世界,使用户能够在该虚拟世界中进行全方位、无死角的观察和交互的技术。VR全景技术模拟人在真实空间中的视觉体验,结合图文、3D、音视频等多媒体元素…...
消息队列系统设计与实践全解析
文章目录 🚀 消息队列系统设计与实践全解析🔍 一、消息队列选型1.1 业务场景匹配矩阵1.2 吞吐量/延迟/可靠性权衡💡 权衡决策框架 1.3 运维复杂度评估🔧 运维成本降低策略 🏗️ 二、典型架构设计2.1 分布式事务最终一致…...


