4、mysql高阶语句

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.mzph.cn/pingmian/64905.shtml

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

相关文章

Docker部署GitLab服务器

一、GitLab介绍 1.1 GitLab简介 GitLab 是一款基于 Git 的开源代码托管平台&#xff0c;集成了版本控制、代码审查、问题跟踪、持续集成与持续交付&#xff08;CI/CD&#xff09;等多种功能&#xff0c;旨在为团队提供一站式的项目管理解决方案。借助 GitLab&#xff0c;开发…

hadoop中hive本地模式安装mysql源不成功

目录 1.更改DNS配置 2.替换yun源 3.替换掉后&#xff0c;在执行 4.重新安装mysql源 hive本地模式安装mysql源出错 yum install mysql mysql-server mysql-devel -y 解决&#xff1a; 1.更改DNS配置 vi /etc/resolv.conf 添加下面内容&#xff1a; nameserver 8.8.8.8 …

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

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

Day13 苍穹外卖项目 工作台功能实现、Apache POI、导出数据到Excel表格

目录 1.工作台 1.1 需求分析和设计 1.1.1 产品原型 1.1.2 接口设计 1.2 代码导入 1.2.1 Controller层 1.2.2 Service层接口 1.2.3 Service层实现类 1.2.4 Mapper层 1.3 功能测试 1.4 代码提交 2.Apache POI 2.1 介绍 2.2 入门案例 2.2.1 将数据写入Excel文件 2.2.2 读取Excel文…

集星獭 | 高性能编排:为实时数据集成而生!

概要介绍 服务编排作为集星獭驱动业务流、数据流中不可或缺的重要环节&#xff0c;其基于分布式架构打造&#xff0c;提供了高可用、易扩展的可视化流程任务调度功能。 原服务编排的设计初衷是专注于任务调度&#xff0c;提供高性能任务调度&#xff0c;但是在实时调用方面的…

达梦8-达梦数据的示例用户和表

1、示例库说明&#xff1a; 创建达梦数据的示例用户和表&#xff0c;导入测试数据。 在完成达梦数据库的安装之后&#xff0c;在/opt/dmdbms/samples/instance_script目录下有用于创建示例用户的SQL文件。samples目录前的路径根据实际安装情况进行修改&#xff0c;本文将达梦…

windwos defender实现白名单效果(除了指定应用或端口其它一律禁止)禁止服务器上网

一、应用场景说明 当我们的一台windows服务器中毒&#xff0c;变成别人肉鸡&#xff0c;不断向外请示非法网站或攻击其它服务器。 要彻底清除相关木马或病毒往往需要的时间比较长&#xff0c;比较有效的方法是禁止服务器主动向外发包除了网站端口和远程程序除外。 其实这就是一…

1 JVM JDK JRE之间的区别以及使用字节码的好处

JDK jdk是编译java源文件成class文件的&#xff0c;我们使用javac命令把java源文件编译成class文件。 我们在java安装的目录下找到bin文件夹&#xff0c;如下图所示: 遵循着编译原理&#xff0c;把java源文件编译成JVM可识别的机器码。 其中还包括jar打包工具等。主要是针对…

【机器人】机械臂轨迹和转矩控制对比

动力学控制和轨迹跟踪控制是机器人控制中的两个概念&#xff0c;它们在目标、方法和应用上有所不同&#xff0c;但也有一定关联。以下是它们的区别和联系&#xff1a; 1. 动力学控制 动力学控制是基于机器人动力学模型的控制方法&#xff0c;目标是控制机器人关节力矩或力&…

Pytorch | 从零构建ParNet/Non-Deep Networks对CIFAR10进行分类

Pytorch | 从零构建ParNet/Non-Deep Networks对CIFAR10进行分类 CIFAR10数据集ParNet架构特点优势应用 ParNet结构代码详解结构代码代码详解SSEParNetBlock 类DownsamplingBlock 类FusionBlock 类ParNet 类 训练过程和测试结果代码汇总parnet.pytrain.pytest.py 前面文章我们构…

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…

Unity中的委托和事件(UnityAction、UnityEvent)

委托和事件 &#x1f392;什么是委托&#xff0c;委托的关键字是Delegate&#xff0c;委托是一种函数的容器&#xff0c;运行将函数做为变量来进行传递 通过Delegate关键字我们声明了一个无参无返回的委托&#xff0c;通过这个委托我们可以存储无参无返回的函数 public deleg…

uniapp v-tabs修改了几项功能,根据自己需求自己改

根据自己的需求都可以改 这里写自定义目录标题 1.数组中的名字过长&#xff0c;导致滑动异常2.change 事件拿不到当前点击的数据&#xff0c;通过index在原数组中查找得到所需要的id 各种字段麻烦3.添加指定下标下新加红点显示样式 1.数组中的名字过长&#xff0c;导致滑动异常…

CAD xy坐标标注(跟随鼠标位置实时移动)——C#插件实现

效果如下&#xff1a; &#xff08;使用方法&#xff1a;命令行输入 “netload” 加载此dll插件&#xff0c;然后输入“zbbz”运行&#xff0c;选择文件夹即可。支持字体大小变化&#xff0c;输入“zbbd”可设置坐标字体变大或缩小的倍数&#xff09; 部分代码如下&#xff1a;…

【C#】实现Json转Lua (Json2Lua)

关键词: C#、JsonToLua、Json2Lua、对象序列化Lua 前提需引入NewtonsofJson&#xff0c;引入方法可先在Visual Studio 2019 将Newtonsoft.Json.dll文件导入Unity的Plugins下。 Json格式字符串转Lua格式字符串&#xff0c;效果如下&#xff1a; json字符串 {"1": &q…

Redis 7.x如何安装与配置?保姆级教程

大家好&#xff0c;我是袁庭新。最新写了一套最新版的Redis 7.x企业级开发教程&#xff0c;今天先给大家介绍下Redis 7.x如何在Linux系统上安装和配置。 1 Redis下载与安装 使用非关系型数据库Redis必须先进行安装配置并开启Redis服务&#xff0c;然后使用对应客户端连接使用…

Redis篇--常见问题篇6--缓存一致性1(Mysql和Redis缓存一致,更新数据库删除缓存策略)

1、概述 在使用Redis作为MySQL的缓存层时&#xff0c;缓存一致性问题是指Redis中的缓存数据与MySQL数据库中的实际数据不一致的情况。这可能会导致读取到过期或错误的数据&#xff0c;从而影响系统的正确性和用户体验。 为了减轻数据库的压力&#xff0c;通常读操作都是先读缓…

git remote -v(--verbose)显示你的 Git 仓库配置的远程仓库的详细信息

git remote -v 是一个 Git 命令&#xff0c;用于显示你的 Git 仓库配置的远程仓库的详细信息。 当你执行 git remote -v 命令时&#xff0c;你会看到类似以下的输出&#xff1a; origin https://github.com/your-username/your-repo.git (fetch) origin https://github.com…

[计算机网络]唐僧的”通关文牒“NAT地址转换

1.NAT&#xff1a;唐僧的通关文牒 在古老的西游记中&#xff0c;唐僧师徒四人历经九九八十一难&#xff0c;终于取得了真经。然而&#xff0c;他们并不是一开始就获得了通关文牒&#xff0c;而是经过了重重考验&#xff0c;最终得到了国王的认可&#xff0c;才顺利通过了各个关…

WPF实现曲线数据展示【案例:震动数据分析】

wpf实现曲线数据展示&#xff0c;函数曲线展示&#xff0c;实例&#xff1a;震动数据分析为例。 如上图所示&#xff0c;如果你想实现上图中的效果&#xff0c;请详细参考我的内容&#xff0c;创作不易&#xff0c;给个赞吧。 一共有两种方式来实现&#xff0c;一种是使用第三…