stotybord如何添加子视图_SQL复杂查询-子查询

视图:

1.视图的概念引入:

SQL数据库里面存放的是SQL语句,视图中查看到的SQL查询语句,当我们运用客户端连接到视图时候,视图会运行里面的查询语句,从库中查找出数据,保存在临时表里面。当客户端和数据库断开时,表会被自动删除。不是保存在SQL数据库里面。

0ba0055431caeb707a1fa7ce3edfd910.png

2.如何创建视图;

Code: create view 视图名称(<视图列名1>,<视图列名2>...) as <select查询语句>

3.为什么要使用视图:

  1. 不需要重复工作:某些大量重复使用的SQL语句,可以保存为视图,不需要每次运用时都去写SQL语句。类似Excel中给每个表写好函数,基础数据变动,设计好的函数结果就会变化。
  2. 自动更新: 如上述说的,基础数据变化,视图中函数结果就会发生变化
  3. 节省存储空间:减少存放数据设备的空间。视图不需要保存数据。

注意事项:

1.不要重复新建视图,会降低SQL性能效率

2.不能忘视图里面插入数据,会报错。

eg.在工作中需要常常用性别来汇总计算,就写好视图。数据库中数据表动,视图中函数得出结果也会相对应变动。

create view 按性别汇总(性别,人数)as select 性别,count(*) from student group by 性别;

6b0bda0b98088d772d8dfef18f742038.png

1abf84a86d50ebadbecb9199bdeb4ff2.png

多条件子查询

19a00e7e3d81a6cfb987948a7ac3c925.png

以下代码根据此四个基础原表:

cfb5781ad4945df7942086f82c89ffc2.png

【原数据表】

1)IN(子查询)--在...之一

相当于or

题目】:找出每个课程里 成绩最低的学号

第一时间可能想到的是如下语句,但这个是错误的:

92cff1f93901904ed4b6a1455fd09331.png

理解思路1】:理解这个代码错误的原因要从SQL运行顺序上去想。首先从Score表里面提取数据并根据课程号进行数据分组,然后执行应用函数min(成绩)。此时得出的结果只有课程号和成绩。然后再进行组合和随机学号的加入。

fc5fc89ebb42d06ec4675221414b287b.png

理解思路2 】:因此应该要用子函数进行嵌套,首先子函数先运行,找出每门课程对应最低成绩是多少。然后运行主句。在选出的每门课的最低成绩中,找出对应的学生学号。

75a8a3609b6578c74424b5c699922d06.png

2)Any(子查询)/some(子查询)在...(子查询)之一

一般用于比较,接于比较运算符之后。

select<列名1> from <表名> where<列名> > any(子查询)

eg.

e6b9401bcfbd2a39d8dc6bb5f356bb47.png

解析】:

dd2b37188df30829664f06c6af905df8.png

3)all(子查询) 全部...

一般用于比较,接于比较运算符之后。

eg.

e332cb0129e6c435a0edcac4e23b3275.png

标量子查询

标量子查询和一般子查询相比,其特征是标量子查询得出来只有一个值,一般子查询可能会有一个值会有多个值,所以他们之间是包含关系。

标量子查询多用于比较运算符后。例如小于大于等于之后。但也可用于主句中,当显示结果为唯一值时。

fbac10fcd2b18c2f949af347e0f46b5e.png

解析】:select avg(成绩)from score的出来只有一个数值。

3c583a316c9329c1b89019528eca0c10.png

eg2.

16076a0a0a4780acbe227f3668989298.png

关联子查询:

在进行在每个组里比较的时候会用到关联子查询,先看下面栗子:

栗子中,希望找出大于没个课程平均成绩的学生,但是select子从句的出来的结果是三个值(因为有三个课程)而非一个值,这个导致不能直接使用标量子查询。

e98dad957bd3e2f8d6823efa552d6eb2.png

解决方法】:

子从句中加入 where 条件。

e4d13fe95d50a78e08535514507ec074.png

在子查询加入where之后,得出来的结果虽然仍然是‘0001,'0002','0003'三个课程的平均成绩,但是这三个课程的平均成绩因为有where 进行限定,所以是一 一对应的关系。主句中出现0001课程的成绩,就会对子查询中0001值出现的平均成绩进行比对,不再是一对三,而是实现一对一的效果。

cfbc9afb720c1da52247062af84a52b8.png

子查询注意事项:

  1. 不建议层层嵌套子查询,这会造成数据库运行速度减慢。 select... from (子查询(子查询))
  2. 子查询用as 来标记方便阅读。 select ...from...子查询 as 子查询名称

【sqlzoo练习】-->select in select:

b42b4cd53a859ba5398ba6556564ee34.png

2ab68abf2e91207f81ac5b40a70acbc3.png

5a7e9b6499e193afc0ffaadb9341b274.png

8be1fb5e91f8b065213a216d1c856b37.png

8060c2e450f2d542ccc20f0dc608263c.png

ee17187adcda2449aedba500dacde605.png

51ebd8a3e7c9123c9f1de5ec61627ab2.png

8a50fd08b4ae11da5bd518bf7cbcc138.png

92331de90b06d6027b95a6cef2ec2d97.png

19b0b24357fdbd8e843d9902a92b2835.png

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

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

相关文章

springboot 2.3_Spring Boot 应用监控,早发现早

小Hub领读&#xff1a;服务都需要监控&#xff0c;SpringBoot项目中&#xff0c;你常用哪些监控模块呢&#xff1f;actuator?admin?作者&#xff1a;小小____https://segmentfault.com/a/1190000022945443当一个 Spring Boot 应用运行的时候&#xff0c;开发者需要对 Spring …

sql statements_Postgresql监控sql模块之pg_stat_statements模块--部署篇

概述今天主要介绍一下PG一个很重要的模块--pg_stat_statements模块&#xff0c;对于做性能观察还是很不错的。一、pg_state_statements模块简介1、简介pg_stat_statements模块提供一种方法追踪一个服务器所执行的所有 SQL 语句的执行统计信息&#xff0c;可以用于统计数据库的资…

linux服务配置大全 fedora 8 ftp 百度文库,Linux下VSFTP配置全攻略

Linux下VSFTP配置全攻略[日期&#xff1a;2007-10-05]来源&#xff1a;Linux公社作者&#xff1a;Linuxidc[字体&#xff1a;大 中 小]4]如果要以系统中存在的普通用户登入FTP&#xff0c;也没有什么可以设置的&#xff0c;添加一个用户就行。比如我要添加beinan这个用户&#…

sqlserver 还原bak文件 查看不到_SQL server中用T-SQL语句实现(建库,分离,附加,备份,还原)...

会用图形界面创建后&#xff0c;今天可以学习用T-SQL来创建数据库及对数据库的操作。一. T-SQL 创建数据库--创建数据库create database MySchool--创建数据库 数据库名称MySchoolon primary(--创建主数据库文件nameMySchool_data,--主数据库文件名称fileNameD:MySchool_data.m…

win7变成linux桌面背景,教大家把Ubuntu界面改造成Windows7系统

经常使用windows7系统的用户可能比较喜欢windows7系统强大的系统界面&#xff0c;下面就教大家如何使Ubuntu看起来像Windows 7系统的界面&#xff0c;具体内容如下所述&#xff0c;Ubuntu自身拥有相当不错的主题系统、视觉效果和养眼的画面&#xff0c;但你可能喜欢windows7的A…

怎么通过MQTT查看数据是否上云端_设备工程师们的福利来啦!JSON数据采集网关帮你实现云端对接~...

JSON数据采集网关是一种能够将各种传感器的数据采集后按照JSON格式上传服务器的网关。图 JSON数据采集网关工作原理示意图JSON(JavaScript Object Notation)是java中的数据格式。例如{“power”:”100”, “time”:”10:12:23”}这样的格式&#xff0c;由于它简单易用&#xff…

oracle 会话数上不去_Oracle初识

1、基本概念oracle数据库是一个物理概念&#xff0c;oracle实例是数据库在内存中的镜像&#xff0c;属于一种逻辑概念。oracle数据库与oracle实例至少是一对一的关系&#xff0c;也可能是一对多关系&#xff08;oracle集群&#xff1a;RAC real application cluster&#xff09…

trace Linux and实例,traceroute在linux中的使用方法

traceroute在linux中的使用方法一、traceroute的实现原理1、IP协议利用存活时间TTL来发出探测包跟踪数据包到达目标ip主机所经历的路由网关数量&#xff0c;每经过一个路由器&#xff0c;TTL的值就减去1。当TTL值为0时&#xff0c;主机就取消发送数据包&#xff0c;并回传一份I…

在VS中怎么用vb画矩形_(十四)矩形和操作展示逻辑操作

时间为友&#xff0c;记录点滴。聊了这么多的图片运算&#xff0c;忽然有个想法&#xff0c;为什么非要用静态的图片来展示运算呢&#xff1f;我们可以用自己做的图片来经过运算后显示出来。说干就干。先想一下需求&#xff1a;整体环境非黑即白。可以用鼠标在背景上画出矩形&a…

c++ 二维数组 排序_漫画:“排序算法” 大总结

​冒泡排序&#xff1a;漫画&#xff1a;什么是冒泡排序&#xff1f;​mp.weixin.qq.com选择排序&#xff1a;漫画&#xff1a;什么是选择排序&#xff1f;​mp.weixin.qq.com插入排序&#xff1a;漫画&#xff1a;什么是插入排序&#xff1f;​mp.weixin.qq.com此外还有冒泡排…

ieee39节点系统介绍_Java秒杀系统实战系列-基于ZooKeeper的分布式锁优化秒杀逻辑...

本文是“Java秒杀系统实战系列文章”的第十六篇&#xff0c;本文我们将继续秒杀系统的优化之路&#xff0c;采用统一协调调度中心中间件ZooKeeper控制秒杀系统中高并发多线程对于共享资源~代码块的并发访问所出现的并发安全问题&#xff0c;即用ZooKeeper实现一种分布式锁&…

centos配置c语言环境变量,CentOS7设置环境变量

一、环境变量的概念1、环境变量的含义程序(操作系统命令和应用程序)的执行都需要运行环境&#xff0c;这个环境是由多个环境变量组成的。2、环境变量的分类1)按生效的范围分类。系统环境变量&#xff1a;公共的&#xff0c;对全部的用户都生效。用户环境变量&#xff1a;用户私…

python 3.7.732位安装步骤_Python3.7安装pyaudio教程解析

本人笔记本电脑安装的是 python3.7, 64位操作系统&#xff0c;基于x64的处理器 因为 pyaudio 暂时不支持 python3.7 和 3.8&#xff0c;所以若需要安装 pyaudio 需要下载 whl 文件后再离线进行安装。 首先&#xff1a;下载安装 pyaudio 的 whl 文件 然后按下 ctrlf 输入关键字&…

python open写入_Python3 open() 函数详解 读取文件写入文件追加文件二进制文件

Python3 open() 函数详解 读取文件写入文件追加文件二进制文件 open()函数的主要作用是打开文件并返回相应文件对象&#xff0c;使用文件对象可以对当前文件进行读取、写入、追加等操作&#xff0c;默认情况下"r"模式&#xff0c;文件不存在的话会发生OSError错误的。…

一部分 数据 迁移_从虚机到容器,知名架构师告诉你如何平滑进行业务迁移

【小宅按】近期&#xff0c;短视频产品“秒拍”完成了一个“大动作”——将原来部署在虚拟机上的主体业务迁移到华为云&#xff0c;同时将公司的技术体系承载在下一代虚拟技术容器&#xff08;Docker&#xff09;上。而这一系列动作是在业务不下线&#xff0c;用户无感知的前提…

cuda 实现sift gpu_为Keras提供GPU加速

在刚入坑机器学习时&#xff0c;书上所使用的算法&#xff08;回归、决策树等&#xff09;及实例较为简单&#xff0c;一般CPU&#xff08;中央处理器&#xff09;的计算能力均能胜任&#xff0c;从而快速实现。但若使用keras&#xff08;一种基于深度学习框架的高级应用接口&a…

此 sqltransaction 已完成;它再也无法使用_win10笔记本自带office报错无法激活的解决方法...

激活win10笔记本电脑自带office出错怎么办?不少笔记本电脑在出厂的时候就自带windows 10操作系统并且将系统部署完成后就有许多软件集成当中&#xff0c;一般按正常步骤进行激活即可正常使用&#xff0c;不过有用户遇到一个问题&#xff0c;在激活自带office时报错了&#xff…

bat 连续读取两行_Redis底层数据结构解析(BAT大厂必问)

Redis是一个key-value存储系统&#xff0c;现在在各种系统中的使用越来越多&#xff0c;大部分情况下是因为其高性能的特性&#xff0c;被当做缓存使用。Redis由于其丰富的数据结构也可以被应用到其他场景。Redis是一个K-V的非关系型数据库&#xff08;NoSQL&#xff09;&#…

smart原则_为什么现在少有人用德鲁克的SMART原则做目标管理了?

互联网平台充斥了各类成功学文章&#xff0c;但大多数鸡汤文只谈坚持&#xff0c;不谈策略。王健林定下一个亿的小目标被网友编成了各种段子&#xff0c;却极少有人去探究他实现目标的过程&#xff0c;用的什么方法。从企业规模来看&#xff0c;我们没有理由说王健林定下的目标…

团队组成五个基本要素_【记录】综合分部宁波分队团队拓展活动

初冬&#xff0c;像一位美丽的、高贵的、矜持的公主&#xff0c;舞动着她那神奇的面纱&#xff0c;送来阵阵凛冽的寒风。今年宁波分队队伍逐渐壮大&#xff0c;从年初的70多人到目前120人&#xff0c;队伍中也迎来了许多00后的小伙伴们&#xff0c;为加强企业文化建设&#xff…