MySQL数据库高阶语句①

目录

一.按关键字排序

1.单字段排序

(1)按分数排序

(2)结合where进行条件筛选

2.多字段排序

(1)查询学生信息先按兴趣id升序排序,再按id升序排序

(2)查询信息按兴趣id降序排序,相同分数id升序排序

3.区间判断及查询不重复

(1)AND/OR

(2)嵌套/多条件

4.distinct 查询不重复记录

二.对结果进行分组

1.按hobbyid相同分组,计算相同分数的学生个数(基于name计数)

2.结合where语句,筛选分数大于等于70的分组,计算学生个数

三.限制结果条目

1.查询所有信息显示前2行记录

2.从第3行开始,显示后2行内容

3.查询单独行记录

4.结合order by语句,按id的大小升序显示前三行

四.设置别名 alias——》as

1.查询ky35表的字段数量,以number显示

2.as还可以作为连接语句的操作符

五.通配符

1.查询名字以w开头的记录

2.具体查询某个字段

3.查询名字中间有m的

4.查询w后面4个字符的名字记录

5.查询以z开头的字段(模糊查询)


一.按关键字排序

使用 SELECT 语句可以将需要的数据从 MySQL 数据库中查询出来,如果对查询的结果进行排序,可以使用 ORDER BY 语句来对语句实现排序,并最终将排序后的结果返回给用户。这个语句的排序不光可以针对某一个字段,也可以针对多个字段

​select 字段 from 表名 order by 字段 ASC|DESC​
 
​ASC|DESC​
 
​ASC 是按照升序进行排名的,是默认的排序方式,即ASC可以省略​
 
​DESC 是按照降序的方式进行排序的​
 
​order by 也可以通过 where 子句对查询结果进行进一步的过滤​
 
​可进行多字段的排序

1.单字段排序

(1)按分数排序

默认是升序,加desc是降序

select * from info order by score; (asc默认省略)

select * from info order by score desc;

(2)结合where进行条件筛选
select * from info where address=’nanjing’ order by score desc;

2.多字段排序

ORDER BY语句也可以使用多个字段来进行排序,当排序的第一个字段相同的记录有多条的情况下,这些多条的记录再按照第二个字段进行排序,ORDER BY后面跟多个字段时,字段之间使用英文逗号隔开,优先级是按先后顺序而定,但order by之后的第一个参数只有在出现相同值时,第二个字段才有意义

(1)查询学生信息先按兴趣id升序排序,再按id升序排序
select * from info order by hobbid,id;

(2)查询信息按兴趣id降序排序,相同分数id升序排序
select * from info order by hobbid,id desc;

3.区间判断及查询不重复

(1)AND/OR
select * from info where score>70 and score<=90;
 
select * from info where score>70 or score<=90;

(2)嵌套/多条件
select * from info where score>70 or (score>75 and score <90);
 
select * from info where score>70 and (score>75 and score <90);

4.distinct 查询不重复记录

select distinct 字段 from 表名﹔
 
 distinct 必须放在最开头
 
 distinct 只能使用需要去重的字段进行操作
 
 distinct 去重多个字段时,含义是:几个字段同时重复时才能被过滤,会默认按左边第一个字段为依据。

查看hobbyid有多少种

select distinct hobbid from info;

二.对结果进行分组

通过 SQL 查询出来的结果,还可以对其进行分组,使用 GROUP BY 语句来实现 ,GROUP BY 通常都是结合聚合函数一起使用的,常用的聚合函数包括:计数(COUNT)、 求和(SUM)、求平均数(AVG)、最大值(MAX)、最小值(MIN),GROUP BY 分组的时候可以按一个或多个字段对结果进行分组处理。

select 字段,聚合函数 from 表名 (where 字段名(匹配) 数值) group by 字段名;

1.按hobbyid相同分组,计算相同分数的学生个数(基于name计数)

2.结合where语句,筛选分数大于等于70的分组,计算学生个数

全班同学成绩表
count(name):计数  score 分数 :
 
score>=80 :优秀
score >=60 and score <80 :优
 
结合order by把分数按降序排列
select count(name),score from info where score > 80 group by score oeder by score desc;

三.限制结果条目

在使用 MySQL SELECT 语句进行查询时,结果集返回的是所有匹配的记录(行)。有时候仅需要返回第一行或者前几行,这时候就需要用到LIMIT子句

select 字段 from 表名 limit [offset,] number
 
limit 的第一个参数是位置偏移量(可选参数),是设置 mysql 从哪一行开始
 
如果不设定第一个参数,将会从表中的第一条记录开始显示。
 
第一条偏移量是0,第二条为1
 
offset 为索引下标
 
number 为索引下标后的几位

1.查询所有信息显示前2行记录

select * from info limit 2;

2.从第3行开始,显示后2行内容

select * from info limit 3,2;

3.查询单独行记录

select * from info limit 3,1;

4.结合order by语句,按id的大小升序显示前三行

select * from info order by id limit 3;

四.设置别名 alias——》as

在 MySQL 查询时,当表的名字比较长或者表内某些字段比较长时,为了方便书写或者多次使用相同的表,可以给字段列或表设置别名。使用的时候直接使用别名,简洁明了,增强可读性。

对于列的别名:SELECT column_name AS alias_name FROM table_name;
对于表的别名:SELECT column_name(s) FROM table_name AS alias_name;

1.查询ky35表的字段数量,以number显示

mysql> select count(*) as number from info;

2.as还可以作为连接语句的操作符

创建tab1表,将info表的查询记录全部插入t1表
create table info_bak as select * from info;

克隆、复制表结构

create table t1 (select * from info);

#也可以加入where 语句判断

create table test1 as select * from info where score >=60;

在为表设置别名时,要保证别名不能与数据库中的其他表的名称冲突。

列的别名是在结果中有显示的,而表的别名在结果中没有显示,只在执行查询时使用。

五.通配符

通配符主要用于替换字符串中的部分字符,通过部分字符的匹配将相关结果查询出来。

  • 通常通配符都是跟LIKE 一起使用的,并协同 WHERE!
  • 子句共同来完成查询任务。常用的通配符有两个,分别是:
    • %:百分号表示零个、或者多个字符
    • _:下划线表示单个字符
通配符含义
%表示零个,一个或者多个字符
_下划线表示单个字符
A_Z所有以A开头 Z 结尾的字符串 ‘ABZ’ ‘ACZ’ 'ACCCCZ’不在范围内 下划线只表示一个字符 AZ 包含a空格z
ABC%所有以ABC开头的字符串 ABCD ABCABC
%CBA所有以CBA结尾的字符串 WCBA CBACBA
%AN%所有包含AN的字符串 los angeles
_AN%所有 第二个字母为 A 第三个字母 为N 的字符串

1.查询名字以w开头的记录

select id,name from 表名 where name like ‘%w’;

2.具体查询某个字段

3.查询名字中间有m的

4.查询w后面4个字符的名字记录

5.查询以z开头的字段(模糊查询)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

视频素材网站哪个比较好?8个优质视频素材软件app推荐

在探索那些能够让视频作品焕发生机的宝藏网站时&#xff0c;一个好的短视频素材库不仅能提升作品的视觉效果&#xff0c;还能赋予作品更深的情感层次。为了帮助你更好地寻找到这些珍贵的资源&#xff0c;以下是一系列精选的视频素材网站&#xff0c;全面支持你的视频创作需求。…

低照度图像增强算法---传统算法篇

YOLOv8n原图检测YOLOv8n增强后检测召回率和置信度都有提升 前言 这篇博客讲讲低照度,大家都催我出一些内容,没想到这么多同学搞这个,恰好我也做过这方面的一些工作,那今天就来讲解一些方法,低照度的图像增强大体分“传统算法”和“深度学习算法”; 目前低照度的图像增…

linux文本三剑客 --- grep、sed、awk

1、grep grep&#xff1a;使用正则表达式搜索文本&#xff0c;将匹配的行打印出来&#xff08;匹配到的标红&#xff09; 命令格式&#xff1a;grep [option] pattern file <1> 命令参数 -A<显示行数>&#xff1a;除了显示符合范本样式的那一列之外&#xff0c;并…

bsd猜想 Murmuration of Eliptic Curves(笔记)

BSD Alexey Pozdnyakov (University of Connecticut) YUTUBE视频&#xff0c; B站搬运地址新生代女数学家Nina Zubrilina得到椭圆曲线椋鸟群飞模式精确公式与证明 Arithmetic Geometry算术几何 希尔伯特第十问题 希尔伯特第十问题&#xff08;Hilbert’s Tenth Problem&#…

Elasticsearch8 - Docker安装Elasticsearch8.12.2

前言 最近在学习 ES&#xff0c;所以需要在服务器上装一个单节点的 ES 服务器环境&#xff1a;centos 7.9 安装 下载镜像 目前最新版本是 8.12.2 docker pull docker.elastic.co/elasticsearch/elasticsearch:8.12.2创建配置 新增配置文件 elasticsearch.yml http.host…

WordPress网站已经安装了SSL证书,但浏览器仍然提示不安全

WordPress网站已经安装了SSL证书&#xff0c;但浏览器仍然提示不安全 昨天我们新建了一个WordPress的网站&#xff0c;在已经安装了SSL证书的情况下&#xff0c;访问网站仍然会提示不安全。 我们使用的是Hostease提供的虚拟主机产品&#xff0c;之前从未出过这样的情况&#x…

【优选算法】专题1 -- 双指针 -- 复写0

前言&#xff1a; 补充一下前文没有写到的双指针入门知识&#xff1a;专题1 -- 双指针 -- 移动零 目录 基础入门知识&#xff1a; 1. 复写零&#xff08;easy&#xff09; 1. 题⽬链接&#xff1a;1089.复习0 - 力扣&#xff08;LeetCode&#xff09; 2. 题⽬描述&#xff…

大词汇量高质量3D物体生成需要解决哪些问题?如何解决?

作者:Vallee | 来源:计算机视觉工坊 在公众号「计算机视觉工坊」后台,回复「原论文」可获取论文pdf和代码链接 DiffTF: 基于Transformer的大词汇量3D扩散模型 大词汇量3D物体生成 最近基于扩散模型的3D生成方法大火,但如何生成大量类别且高质量的3D模型还没得到很好地解决…

喜获千万元价值补贴,探索 AI 领域新应用:Zilliz 全力支持 AI 初创企业

价值 1000 万元的大额补贴&#xff01;得到领先全行业的向量数据库团队支持&#xff01;尽享独家生态资源&#xff01;「Zilliz AI 初创计划」正式开启&#xff01; 「Zilliz AI 初创计划」是 Zilliz 面向 AI 初创企业推出的一项扶持计划&#xff0c;预计提供总计 1000 万元的 …

Docker 哲学 - tmpfs 存储

tem&#xff1a;temporary 暂时的 背景&#xff1a;只有在 linux 有该种方式 If youre running Docker on Linux, you have a third option: tmpfs mounts. When you create a container with a tmpfs mount, the container can create files outside the containers writabl…

数据库-事务

简介 事务&#xff08;Transaction&#xff09;是指数据库管理系统&#xff08;DBMS&#xff09;中执行的一个操作序列&#xff0c;这些操作要么全部成功执行&#xff0c;要么全部不执行&#xff0c;且在执行过程中保持数据的一致性。 例如&#xff1a; 张三给李四转账&#…

知识图谱推理算法综述(上):基于距离和图传播的模型

背景 知识图谱系统的建设需要工程和算法的紧密配合&#xff0c;在工程层面&#xff0c;去年蚂蚁集团联合 OpenKG 开放知识图谱社区&#xff0c;共同发布了工业级知识图谱语义标准 OpenSPG 并开源&#xff1b;算法层面&#xff0c;蚂蚁从知识融合&#xff0c;知识推理&#xff…

前三次笔记、表单和五彩导航

骨架&#xff1a; 笔记&#xff1a; 需要有包裹的内容&#xff0c;用双标签&#xff0c;不需要包裹内容就可以完成的操作用单标签 标签之间的关系只有父子关系和兄弟关系 标题标签只有h1-h6&#xff0c;且大小依次递减&#xff0c;独占一行 在段落标签“<p> </p>”…

【物联网开源平台】tingsboard二次开发

别看这篇了&#xff0c;这篇就当我的一个记录&#xff0c;我有空我再写过一篇&#xff0c;编译的时候出现了一个错误&#xff0c;然后我针对那一个错误执行了一个命令&#xff0c;出现了绿色的succes,我就以为整个tingsboard项目编译成功了&#xff0c;后面发现的时候&#xff…

TransUNet论文笔记

论文&#xff1a;TransUNet&#xff1a;Transformers Make Strong Encoders for Medical Image Segmentation 目录 Abstract Introduction Related Works 各种研究试图将自注意机制集成到CNN中。 Transformer Method Transformer as Encoder 图像序列化 Patch Embed…

windows下的vscode + opencv4.8.0(C++) 配置

1.添加环境变量 D:\mingw64\bin 2.安装vscode 3.下载opencv 4.8.0 4.程序引用第三方库(opencv为例) 打开CMakeLists.txt&#xff0c;引入头文件&#xff0c;使用include_directories 加入头文件所在目录。静态链接库link_directories # 头文件 include_directories(D:/ope…

Java中 List 集合,通过 Stream 流进行排序总结

一、数据准备 public class OrderTest {private String channelCode;private BigDecimal rate;// 省略 getter、setter、toString()、constructor }List<OrderTest> orderTestList new ArrayList<>();OrderTest z09 new OrderTest("Z09", new BigDeci…

[Qt学习笔记]Qt实现自定义控件SwitchButton开关按钮

1、功能介绍 在项目UI中使用较多的打开/关闭的开关按钮&#xff0c;一般都是找图片去做效果&#xff0c;比如说如下的图像来表征打开或关闭。 如果想要控件有打开/关闭的动画效果或比较好的视觉效果&#xff0c;这里就可以使用自定义控件&#xff0c;使用Painter来绘制控件。软…

C++ primer 第十五章

1.OPP:概述 面向对象程序设计的核心思想是数据抽象、继承和动态绑定。 通过继承联系在一起的类构成一种层次关系&#xff0c;在层次关系的根部的是基类&#xff0c;基类下面的类是派生类 基类负责定义在层次关系中所有类共同拥有的成员&#xff0c;而每个派生类定义各自特有…

FFmpeg+mediamtx 实现将本地摄像头推送成RTSP流

文章目录 概要推流过程实现过程安装FFmpeg安装Mediamtx 启动推流 概要 FFmpegmediamtx实现将本地摄像头推送成RTSP流 FFmpeg 版本号为&#xff1a;N-114298-g97d2990ea6-20240321 mediamtx 版本号为&#xff1a;v1.6.0 推流过程 摄像头数据&#xff0c;经过ffmpeg的推流代码…