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,一经查实,立即删除!

相关文章

python模拟登录页面下载_python爬虫之模拟登录

最近应朋友要求&#xff0c;帮忙爬取了小红书创作平台的数据&#xff0c;感觉整个过程很有意思&#xff0c;因此记录一下。在这之前自己没怎么爬过需要账户登录的网站数据&#xff0c;所以刚开始去看小红书的登录认证时一头雾水&#xff0c;等到一步步走下来&#xff0c;最终成…

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

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

linux 内核 xfs ail,linux 3.10内核 xfs的一次io异常导致的hung crash

8556395.925003] XFS (sdi): xfs_log_force: error -5returned.[8556407.425047] INFO: task umount:19286 blocked for more than 1200seconds.----这个默认是120&#xff0c;该环境上是被人为设置1200[8556407.425653] "echo 0 > /proc/sys/kernel/hung_task_timeout…

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

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

vscode 文件夹中查找_VSCode 多文件搜索和替换

本文目录结构VSCode 多文件搜索和替换虽然在“基础入门”这个部分中&#xff0c;我们一直都在介绍编辑器的各种功能&#xff0c;但是&#xff0c;为了把搜索这样的一个功能介绍完整&#xff0c;我们今天就再讲一下在 VS Code 当中如何使用多文件搜索。关于 VSCode 单文件搜索和…

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

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

collector list 多个分组_Java 8嵌套(多级)分组依据

您不能通过多个键对单个项目进行分组&#xff0c;除非您接受该项目可能会出现在多个组中。在这种情况下&#xff0c;您想要执行一种flatMap操作。实现此目的的一种方法是Stream.flatMap与临时对一起使用&#xff0c;以容纳和的组合&#xff0c;Item然后SubItem再进行收集。由于…

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…

深交所a股证券代码_深市和沪市的股票代码应该怎么区别?

展开全部深市和沪市的股票代码的区别如下&#xff1a;1、沪市A股票买卖的代32313133353236313431303231363533e78988e69d8331333365666266码是以600或601打头&#xff0c;如&#xff1a;运盛实业&#xff0c;股票代码是600767&#xff0c;中国国航(7.72,0.32,4.32%)是601111。B…

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

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

小爱音响调用php接口_PHP调用语音合成接口

百度TTS 语音合成//百度文件转换成语音private function toSpeech($text){define(DEMO_CURL_VERBOSE, false);$obj["status">0,"msg">"","file_name">""];//获取秘钥$apiKey Config::get(apiKey);$secretKey Con…

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…

js 点击闭包_学习Javascript闭包(Closure)

讲的很清楚明了&#xff0c;连我都懂了&#xff0c;要是我们大学时的老师也能这么讲课。。。他们只会放幻灯片2009年8月30日 22:29| #| 引用2009年8月30日 22:44| #| 引用呵呵&#xff0c;可以作为面试题了&#xff01;2009年8月31日 09:30| #| 引用十三说&#xff1a;闭包个人…

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

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

linux文件传输到另一台linux,使用scp将文件/目录拷贝到另一台Linux主机上

如何将一台Linux主机上的文件或目录拷贝到另一台Linux主机上&#xff0c;scp命令可以实现该需求前提条件&#xff1a;两台Linux主机处于同一网段&#xff0c;可以互相ping通操作如下&#xff1a;文件拷贝①将本地文件拷贝到远端主机上scp 待拷贝的文件 远端主机用户名远端主机I…

python结构化数据_python新手入门必备—— 使用json保存结构化数据

【摘要】使用 json 保存结构化数据时&#xff0c;字符串可以很轻松地写入文件并从文件中读取出来。数字可能会费点劲&#xff0c;因为 read() 方法只能返回字符串&#xff0c;这些字符串必须传递给类似 int() 的函数&#xff0c;它会接受类似 123 这样的字符串并返回其数字值 1…

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

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

c语言线程经常段错误的是,由pthread_create引起的段异常

由pthread_create引起的段错误一般线程的结束是由进程内的其他线程来结束的&#xff0c;调用pthread_cancel.但是需要考虑到被结束线程的性质&#xff0c;一方面&#xff0c;线程是可被结束&#xff0c;也可无法结束&#xff0c;即不响应该信号&#xff1b;另一方面&#xff0c…