当前位置: 首页 > news >正文

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 单行数据插入:

在这里插入图片描述

  1. 主要需要理解的结构:
    (需要插入的属性列) values(对应的值)
    insert into students (插入中:into可省略,students就是要插入的表名)
  2. 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

实例:

比较运算符
  1. 找英语成绩不合格的人:在这里插入图片描述
between运算符的使用
  1. 语文成绩在 80 ~ 90 分的同学和成绩
    在这里插入图片描述
    上述和使用between a1 and a2 (a1 ~ a2)一样,但between更方便。
    在这里插入图片描述
in运算符的使用

in:如果是 option 中的任意一个,返回 TRUE(1)

  1. 取出数学成绩 58 或 59 或 98或99 的同学和成绩
    可以直接使用 or
    在这里插入图片描述
    也可以使用 math in(58,59,…)
    在这里插入图片描述
like模糊查询

使用 like:

  • %表示模糊查询后面任意多个(包括 0 个)任意字符;
  • _表示模糊查询后面任意一个字符
  1. 查询孙某某(使用%,因为不确定其后面有几个字)
    在这里插入图片描述
    若写成_(就只能查孙某):
    在这里插入图片描述
where后面能使用表达式(和字段)
  1. 语文好于英语成绩
    在这里插入图片描述
  2. 总分在200以下的同学
    在这里插入图片描述
    注意其中不能在where后面使用as重命名的变量,这是因为在select中是where是先执行的,然后才到筛选列,所以也就是as还未定义,无法使用。
    具体执行顺序:
    1. from(先找表)
    2. where(筛选条件),
    3. select(查找的列属性)

所以因为先where,才到列属性,所以重命名是不能使用的(列属性处还未被定义,就不能在where中使用了)

not运算符
  1. 寻找语文成绩大于80且不姓孙在这里插入图片描述

  2. 是孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80

    1. 要么是孙某
    2. 否则:要求总成绩 > 200 and 语文 < 数学 and 英语 > 80
    3. 可先把后面一长串的内容先写 然后 再去加上前面的孙某
      在这里插入图片描述
NULL的查询

重新新建一个表test:
在这里插入图片描述

  1. 查询NULL
    在这里插入图片描述
  2. 查询不为空
    在这里插入图片描述
  3. NULL不参与比较运算,要比较只能使用<=> 、<>
    在这里插入图片描述

2.6 order by语句(结果排序)

  • ASC 为升序(Ascending)(从小到大)
  • DESC 为降序(Descending)(从大到小)
  • 默认为 ASC
  • 没有order by子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序

语法:

SELECT ... FROM table_name [WHERE ...]
ORDER BY column [ASC|DESC], [...];

实操:
ASC升序:

  1. 按数学成绩升序显示
    在这里插入图片描述
  2. 降序desc
    在这里插入图片描述
NULL值在排序中,默认设置为比任何值都要小

在这里插入图片描述

多字段排序,排序优先级随书写顺序

具体理解如下:
查询同学各门成绩,依次按 数学降序,英语降序,语文升序的方式显示
在这里插入图片描述
上图中先按数学降序(数学写在英语前面),当数学相等时才按英语降序,最后才考虑写到最后的语文

建议就是向上图一样,将排序的 方式全部列全出来,不要去使用MySQL默认的情况(无法掌控)

order by默认升序

在这里插入图片描述

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

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

2.7 limit的使用(筛选分页结果)

  1. 直接在select后面加上limit表示需要的行数(从开始到第n行)
    在这里插入图片描述
  2. 当limit 还能从 指定位置开始,读取连续个数(pos,len)(并且注意:开始位置是从0开始的)

如下图:从第一个开始读,3个
在这里插入图片描述

  1. 在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细致内容,早关注不迷路。

http://www.lryc.cn/news/510779.html

相关文章:

  • 从百度云网盘下载数据到矩池云网盘或者服务器内
  • Vue.js 高级组件开发:抽象与高性能架构
  • Kubernetes 安装 Nginx以及配置自动补全
  • CSS---实现盒元素div内input/textarea的focus状态时给父元素加属性!
  • jmeter设置tps、响应时间监测时间间隔
  • WPSJS:让 WPS 办公与 JavaScript 完美联动
  • 深度学习与图像处理(国产深度学习框架——飞桨官方指定教材)
  • taiwindcss
  • 信号的时域截断——频谱泄漏——光晕效应
  • 【Linux编程】TcpServer 类的设计与实现:构建高性能的 TCP 服务器(二)
  • Mono里运行C#脚本8—mono_image_storage_open打开EXE文件
  • XMLHttpRequest的基础知识
  • 力扣矩阵-算法模版总结
  • 如何在短时间内读懂复杂的英文文献?
  • 基于aspose.words组件的word bytes转pdf bytes,去除水印和解决linux中文乱码问题
  • Bert中文文本分类
  • 【深度学习】Java DL4J基于 CNN 构建车辆识别与跟踪模型
  • 【C#】C#打印当前时间以及TimeSpan()介绍
  • 【Linux 网络 (五)】Tcp/Udp协议
  • 多旋翼无人机理论 | 四旋翼动力学数学模型与Matlab仿真
  • Vue3项目中引入TailwindCSS(图文详情)
  • 【开源项目】数字孪生化工厂—开源工程及源码
  • 咨询团队如何通过轻量型工具优化项目管理和提高团队协作效率?
  • javaWeb开发
  • 如何在 Vue 中处理 API 请求?
  • 基于Debian的Linux发行版的包管理工具
  • 2022年国家公考《申论》题(行政执法)
  • 贪心算法(常见贪心模型)
  • git自动压缩提交的脚本
  • Kinova在开源家庭服务机器人TidyBot++研究里大展身手