4、mysql高阶语句

news2024/12/24 19:22:59

mysql高阶语句是对复杂的条件进行查询的操作。

排序—order by

  • 加了desc表示由大到小

1、查询name和score,地址都是云南西路的按id进行由小到大排序

2、查询name和score,先按hobbid进行排序,再把结果按id进行排序

  • 第一段字段必须要有相同的值,第二个字段才有意义。如果先按id排序,再按hobbid排序将毫无意义。

区间判断—and/or

根据where的条件,来对数据进行逻辑的区分,and  /  or

and表示逻辑且,and的所有条件都要为真

or表示逻辑或,只要有一个条件满足即可

1、查询info表所有信息,分数>80且分数<=90

     查询info表所有信息,分数=85或分数=90

区间嵌套

2、查询info表所有信息,分数>80且(分数>90且分数<95)

对结果进行分组查询—group  by

group  by都是和聚合函数一起使用的

  • count():统计函数
  • sum():求和
  • avg():求平均值
  • max():最大值
  • min():最小值

1、按hobbid进行分组,查询name(统计name)和hobbid

  • 不要使用聚合函数的字段来进行分组。
  • 要有多个字段,按照非统计的字段来进行分组。
  • 对聚合函数进行过滤,使用having语句

2、,按hobbid进行分组,查询 score(求平均值)和 hobbid

3、按hobbid进行分组,查询 score(求平均值)和 hobbid,然后挑出score平均值大于85的

  • 对聚合函数进行过滤,使用having语句

4、先根据where条件过滤出成绩大于等于80的,再查询姓名、性别,按照性别来进行分组,统计姓名

  • where只能用在分组之前,不能在分组之后

5、分别统计男生组和女生组的最大成绩和最小成绩

查看指定范围—limit

1、查看从第1行后1行开始,至后面4行,即2-5行

2、显示成绩最高的前三行

数据去重—distinct

1、查询表xy103按address去重的结果

  • 需要去重的类型越多,效果越差

设置别名

1、给列名设置别名

  • as:设置别名,当表名和列名过长的时候可以使用别名进行替代,尤其是在多表联查时,可以不用申明表名

2、给表名设置别名

表示先给表info设置别名a,表info1设置别名b,查询a的兴趣、地址、性别,当a的姓名=b的姓名的时候。

3、创建表时,根据另一张表的结果,直接创建,但是不能继承主键的约束

  • 这种方法只能继承字段、类型等,不能继承主键的约束

通配符—%_

%:表示0个,1个,多个字符,可有可无

_(下划线):表示单个字符

通配符一般是和like一起使用,并且是配和where条件进行过滤

1、%表匹配任意内容

2、匹配 徐x、徐xx和徐x(任意几个x)

  • 几个_代表后面几个字符数量
  • %_表示任意字符数量

子查询

内查询或者嵌套查询,就是在查询语句当中又嵌套着另一个select。

运行时,先查询子语句,然后把子语句的结果传给主语句进行查询。

子查询的表可以是同一张表,也可以是不同的表。

1、先查询name当分数的值大于85的,然后按查询结果查询name和score

  • 前后的条件要一致,多表联查不要超过三张

2、更新info表,设置成绩的值是65,根据子查询的语句,只修改地址有南京的记录的值。

  • 注意:子查询和修改不能对一张表,即不能对自己又查询又修改

exists语句

3、用来判断子查询的结果集是否为空

视图表—view

视图是一个虚拟表,数据基于检索的查询结果。

复杂的查询语句,简单化的呈现给用户。

查询视图就可以获取数据,避免找到真正的表,提高了数据安全。

创建试图表

删除试图表

  • 如果表info里面更新数据,也会同步更新视图表test1,test1相当于查询的一个快捷方式

view和table的区别

  1. 存储方式,表都是实际数据,保存在硬盘,视图存储的不是数据行,而是结果的集合。
  2. 数据更新,更新表可以更新视图,更新视图也可以更新表,一般情况下,视图仅仅用于展示数据。
  3. 占用空间,表示实际空间,视图不占用数据库的空间,就是一个结果。
  4. 视图表的主要作用就是把复杂的查询语句简化成一个查询的集合

连接查询

把两个或者三个表的记录行结合起来,基于这些表之间共同的字段,进行数据的拼接,首先确定一

个主表的结果集(主表的列),然后把其他表的进行选择性的连接到主表的结果上。

内连接—inner  join

结合两个表之间基于一个字段或者多个字段之间,将两个表中结果进行组合。即取交集。

1、查询表test1和test2中,name相等的交集

左连接—left  join

左外连接,在from之后使用left  join或者left  outer  join用关键字来匹配。

左连接以左侧表为基础,接受左表所有的行,并用这些行,与右侧表一起参与,显示左表以及右表

符合条件的行,不满足的显示为null。

2、查询交集,显示左连接左侧表的所有信息;右侧表只显示交集的部分,其余部分为null。

右连接—right  join

右外连接,在from之后使用right  join或者right  outer  join用关键字来匹配。

右连接以右侧表为基础,接受右表所有的行,并用这些行,与左侧表一起参与,显示右表以及左表

符合条件的行,不满足的显示为null。

3、查询交集,显示右连接右侧表的所有信息;左侧表只显示交集的部分,,其余部分为null。

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

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

相关文章

叉车作业如何确认安全距离——UWB测距防撞系统的应用

叉车在工业环境中运行&#xff0c;常常需要在狭窄的空间内完成货物的搬运和堆垛&#xff0c;这对操作员的技术水平和安全意识提出了极高的要求。传统的叉车作业依赖操作员的经验和视觉判断来确认安全距离&#xff0c;然而这种方式往往存在误差&#xff0c;特别是在视线受阻或光…

LLaVA 多模态大模型:两阶段训练,实现视觉与语言模态的高效融合

LLaVA 多模态大模型&#xff1a;两阶段训练&#xff0c;实现视觉与语言模态的高效融合 论文大纲理解确认目标分析过程实现步骤效果展示金手指 结构分析1. 层级结构分析叠加形态&#xff08;从基础到高级&#xff09;构成形态&#xff08;部分到整体&#xff09;分化形态&#x…

PostgreSQL 的历史

title: PostgreSQL 的历史 date: 2024/12/23 updated: 2024/12/23 author: cmdragon excerpt: PostgreSQL 是一款功能强大且广泛使用的开源关系型数据库管理系统。其历史可以追溯到1986年,当时由加州大学伯克利分校的一个研究团队开发。文章将深入探讨 PostgreSQL 的起源、…

台球助教平台系统开发APP和小程序信息收藏功能需求解析(第十二章)

以下是开发台球助教系统客户端&#xff08;APP&#xff0c;小程序&#xff0c;H5&#xff09;几端的信息收藏功能的详细需求和功能说明&#xff0c;内容比较详细&#xff0c;可以说是一个教科书式的详细说明了&#xff0c;这套需求说明不仅仅用在我们的台球助教系统程序上&…

SRE 与 DevOps记录

flashcat https://flashcat.cloud

Linux Shell 脚本编程基础知识篇—shell 运算命令详解

ℹ️大家好&#xff0c;我是练小杰&#xff0c;本文继续Linux shell脚本编程的基础知识内容&#xff0c;接着讲算术运算命令的详细操作~~ 复习&#xff1a;【shell简介以及基本操作】 更多Linux 相关内容请点击&#x1f449;“Linux专栏”~ 文章目录 let运算命令的用法let 的高…

2002 - Can‘t connect to server on ‘192.168.1.XX‘ (36)

参考:2002 - Can‘t connect to server on ‘192.168.1.XX‘ (36) ubantu20.04&#xff0c;mysql5.7.13 navicat 远程连接数据库报错 2002 - Can’t connect to server on ‘192.168.1.61’ (36) 一、查看数据库服务是否有启动&#xff0c;发现有启动 systemctl status mysql…

GitCode 光引计划投稿|MilvusPlus:开启向量数据库新篇章

在人工智能和大数据时代&#xff0c;向量数据库作为处理非结构化数据的核心技术&#xff0c;正变得越来越重要。MilvusPlus&#xff0c;作为「光引计划」的一部分&#xff0c;应运而生&#xff0c;旨在提供一个高性能、易扩展、全功能的向量数据库解决方案。项目背景根植于对现…

一起学Git【第四节:添加和提交文件】

通过前三节的学习,基本上对Git有了初步的了解,下面开始进行文件的添加和提交的流程。 这里主要涉及四个命令: git init 创建仓库git status查看仓库状态git add添加至暂存区git commit提交文件之前已经使用过git init命令了,此处不再具体讲解。参照一起学Git【第二节:创建…

RISC-V架构的压缩指令集介绍

1、压缩指令集介绍 RISC-V的压缩指令集&#xff08;C扩展&#xff09;‌是一种设计用于减少代码大小和提高性能的技术。标准的RISC-V指令是32位&#xff0c;压缩指令集可以将部分32位的指令用16位的指令替代&#xff0c;从未减小程序占用存储空间的大小&#xff0c;提高指令密…

CosyVoice安装过程详解

CosyVoice安装过程详解 安装过程参考官方文档 前情提要 环境&#xff1a;Windows子系统WSL下安装的Ubunt22.4python环境管理&#xff1a;MiniConda3git 1. Clone代码 $ git clone --recursive https://github.com/FunAudioLLM/CosyVoice.git # 若是submodule下载失败&…

docker 容器的基本使用

docker 容器 一、docker是什么&#xff1f; 软件的打包技术&#xff0c;就是将算乱的多个文件打包为一个整体&#xff0c;打包技术在没有docker容器之前&#xff0c;一直是有这种需求的&#xff0c;比如上节课我把我安装的虚拟机给你们打包了&#xff0c;前面的这种打包方式是…

【计算机视觉基础CV-图像分类】05 - 深入解析ResNet与GoogLeNet:从基础理论到实际应用

引言 在上一篇文章中&#xff0c;我们详细介绍了ResNet与GoogLeNet的网络结构、设计理念及其在图像分类中的应用。本文将继续深入探讨如何在实际项目中应用这些模型&#xff0c;特别是如何保存训练好的模型、加载模型以及使用模型进行新图像的预测。通过这些步骤&#xff0c;读…

被裁20240927 --- 嵌入式硬件开发 前篇

前篇主要介绍一些相关的概念&#xff0c;用于常识扫盲&#xff0c;后篇开始上干货&#xff01; 他捧着一只碗吃过百家的饭 1. 处理器芯片1.1 处理器芯片制造商一、 英特尔&#xff08;Intel&#xff09;二、 三星&#xff08;SAMSUNG&#xff09;三、 高通&#xff08;Qualcomm…

【uni-app】2025最新uni-app一键登录保姆级教程(包含前后端获取手机号方法)(超强避坑指南)

前言&#xff1a; 最近在配置uni-app一键登录时遇到了不少坑&#xff0c;uni-app的配套文档较为混乱&#xff0c;并且有部分更新的内容也没有及时更改在文档上&#xff0c;导致部分开发者跟着uni-app配套文档踩坑&#xff01;而目前市面上的文章质量也层次不齐&#xff0c;有的…

C# 范围判断函数

封装范围函数 public static class CommonUtil {/// <summary>/// 范围判断函数&#xff0c;检查给定的值是否在指定的最小值和最大值之间。/// 例如&#xff0c;可以用来判断当前日期是否在开始日期和结束日期之间。/// 该方法适用于任何实现了 IComparable 接口的类型…

一起学Git【第五节:git版本回退】

git reset 是 Git 版本控制系统中一个非常强大的命令&#xff0c;它可以用来重置当前分支到指定的状态&#xff0c;即执行撤销操作或者回退至之前的某一版本&#xff0c;他可以回退至之前的某一个提交状态。有三种主要的用法&#xff1a;git reset --soft&#xff1b;git reset…

谷歌浏览器 Chrome 提示:此扩展程序可能很快将不再受支持

问题现象 在Chrome 高版本上的扩展管理页面&#xff08;地址栏输入chrome://extensions/或者从界面进入&#xff09;&#xff1a; &#xff0c; 可以查看到扩展的情况。 问题现象大致如图: 问题原因 出现此问题的根本原因在于&#xff1a;谷歌浏览器本身的扩展机制发生了…

国标GB28181-2022平台EasyGBS:安防监控中P2P的穿透方法

在安防监控领域&#xff0c;P2P技术因其去中心化的特性而受到关注&#xff0c;尤其是在远程视频监控和数据传输方面。P2P技术允许设备之间直接通信&#xff0c;无需通过中央服务器&#xff0c;这在提高效率和降低成本方面具有明显优势。然而&#xff0c;P2P技术在实际应用中也面…

Go1.21.0 到 Go1.23.0 的改动,向前兼容性和toolchain规则,Go1.21.0,必须升级你的Go啦

Go各版本Release Note Go1.21.0 2023-08-08 https://go.dev/doc/go1.21 内置方法 min & max&#xff1a;返回一个序列中的最大值最小值。 https://go.dev/ref/spec#Min_and_max clear&#xff1a;清空map和slice。 https://go.dev/ref/spec#Clear 标准库 log/slo…