mysql rand() 子查询_MySQL ------ 子查询(十三)

查询(query):任何SQL 都是查询,但此术语一般指select 语句

子查询(subquery):嵌套在查询中的查询,MySQL4.1 引入对子查询的支持。

接下来得就比较有意思了,需要你对于表与表之间的关系有所了解,子查询一般用于跨表查询

一、基本使用

-- 多表查询,返回的订单编码,用于下一次查询 
select cust_id,order_num from orders where order_num in(  select order_num from orderitems where prod_id='fb');

508934b7fa30a4fdd291f0093ccac6d8.png

顺序的就是从里到外,主要就是查询里面套查询

注意:

  1、在select 语句中,子查询总是从内向外处理的,先执行的使括号内的查询语句,根据此查询返回的以IN 操作符要求格式传递到外部查询

  2、包含子查询的select 语句难以阅读和调试,可以 在书写的时候,分为多行并适当缩进

--  三个表查,这其中用到了外键的概念 主要就是 prod_id  order_num cust_id 
select cust_id,cust_name,cust_contact from customers where cust_id in(        select cust_id from orders where order_num in(         select order_num from orderitems where prod_id='tnt2'));

1f0e1e81b95194056d2c8530160a9d74.png

上述,三条主要就是根据商品id 找到对应订单编码,根据订单编码找到客户id ,根据客户id 找到客户信息

注意:

  1、where 子句中使用子查询能够编写出功能很强并且很灵活的sql语句,而且对嵌套的子查询数目也没有限制,不过在实际中语句性能的限制,不能嵌套太多(虽然对子查询数目没有限制,但是由于性能原因,不要嵌套太多

  2、where 子句中使用子查询,应保证select 语句具有与where子句相同数目的列(通常子查询返回单个列并与单个列匹配,若有需要也可以使用多个列),从里到外一层一层

  3、虽然子查询一般与IN 操作符结合使用,但也可以与其他操作符结合使用

  4、使用子查询并不总是执行这种类型的数据检索的最有效方法

二、作为计算字段使用子查询

使用子查询的另一种方法就是创建计算字段,就是查询语句放在select 与from 之间

-- 显示customers 表中每个客户的订单总数,订单与相应的客户id 存储在order 表中select cust_name,cust_state,( select count(*) from orders where orders.cust_id = customers.cust_id) as orders   from customers order by cust_name;

62607f60720c439f05f04414c6524560.png

此语句中 orders.cust_id = customers.cust_id 使用了完全限定,这个可以理解为 根据 orders表中的 cust_id 这个字段进行查询,值为 customers表中的cust_id 的有几个,

如下所示:

93664b9ca65b00e8d21f62556071cb99.png

相关子查询(correlated subquery): 涉及外部查询的子查询。任何时候只要列名可能有多异性,就要使用这种语法(表名点 表中相关列名)。

如果不使用,就是没有完全限定

1d1445b9db33d75105d491351595b3cc.png

两个cust_id 在不同的表中,如果不用完全限定,mysql 假定你是对 order 表中的cust_id 进行自身比较,

34ffc0bf38372f2d31aa60fc85d228bb.png

返回的是order 表中的总数,所以必须限制有歧义性的列名。

注意:

  1、多表查询时要使用完全限定

  2、子查询并不是解决这种数据检索的最有效方法,有多种解决方案

  3、用子查询建立查询的最可靠的方法是逐渐 进行,与mysql 的处理方式相同,建议先测试内层查询,在根据返回的数据测试外层,确人正常后在嵌入到子查询,随牺牲了一点时间但保证了正确。

  4、子查询可以用在 select 与from 之间,也可以用在where 子句后

  5、查询顺序从内到外

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

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

相关文章

centos 6.5 apache mysql php_CentOS 6.5系统安装配置LAMP(Apache+PHP5+MySQL)服务器环境

简单点的:1.关闭SELINUX:setenfo 0 暂时关闭2.安装Apache:yum install httpd3.安装MySQL:yum install mysql mysql-server4.安装PHP:yum install php5.相关的配置:PHP关联MySQL;httpd出错信息…

mysql 如何调用函数结果_MySQL自定义函数调用不出结果

自定义函数的代码:DROP FUNCTION IF EXISTS fn_HrStaffBase_GetNameFromidCarddelimiter //CREATE FUNCTION fn_HrStaffBase_GetNameFromidCard (a VARCHAR(30))RETURNS VARCHAR(50)beginreturn (SELECT staff_name FROM hr_staff_base where idCard a);END //--…

【CodeForces - 987C 】Three displays (dp,最长上升子序列类问题,三元组问题)

题干: It is the middle of 2018 and Maria Stepanovna, who lives outside Krasnokamensk (a town in Zabaikalsky region), wants to rent three displays to highlight an important problem. There are nn displays placed along a road, and the ii-th of th…

git object 很大_这才是真正的Git——Git内部原理

本文以一个具体例子结合动图介绍了Git的内部原理,包括Git是什么储存我们的代码和变更历史的、更改一个文件时,Git内部是怎么变化的、Git这样实现的好处等等。TL;DR本文以一个具体例子结合动图介绍了Git的内部原理,包括Git是什么储存我们的代码…

【CodeForces - 195D】Analyzing Polyline (思维,卡精度的处理方式)

题干: As Valeric and Valerko were watching one of the last Euro Championship games in a sports bar, they broke a mug. Of course, the guys paid for it but the barman said that he will let them watch football in his bar only if they help his son …

【CodeForces - 985D】Sand Fortress (二分,贪心,思维构造,技巧,有坑)

题干: You are going to the beach with the idea to build the greatest sand castle ever in your head! The beach is not as three-dimensional as you could have imagined, it can be decribed as a line of spots to pile up sand pillars. Spots are numbe…

scrapy 分布式 mysql_Scrapy基于scrapy_redis实现分布式爬虫部署的示例

准备工作1.安装scrapy_redis包,打开cmd工具,执行命令pip install scrapy_redis2.准备好一个没有BUG,没有报错的爬虫项目3.准备好redis主服务器还有跟程序相关的mysql数据库前提mysql数据库要打开允许远程连接,因为mysql安装后root用户默认只允许本地连接,详情请看此文章部署过程…

(精)DEVC++的几个实用小技巧

依赖 DEV C 5.11 最新版 下载安装DEV C后,使用DEV C打开一个随便的cpp文件,你看到的应该是这样的界面。(为了节约读者的流量,图片进行了有损压缩,但是字看得清楚) 重点是确认工具栏有AStyle选项。 相信…

win10一按右键就闪屏_升级Win10正式版后屏幕一直闪烁正确的解决办法

Win10正式版屏幕一直闪烁怎么办呢?升级到Win10正式版并进入Windows桌面后,发现屏幕一直不断的闪烁,此时无法执行任务操作。小编最近在升级到Win10正式版后才遇到了这个问题,后台经过反复思考和探索,终于解决了问题&…

*【CodeForces - 195B】After Training (多解,模拟)

题干: After a team finished their training session on Euro football championship, Valeric was commissioned to gather the balls and sort them into baskets. Overall the stadium has n balls and m baskets. The baskets are positioned in a row from l…

pandas打印全部列_python——pandas练习题1-5

练习1-开始了解你的数据探索Chipotle快餐数据相应数据集:chipotle.tsvimport pandas as pd chipopd.read_csv("exercise_data/chipotle.tsv",sept) chipo.head(5)chipo.shape[0] #查看有多少行4622chipo.shape[1] #查看有多少列5chipo.columns #打印所…

【CodeForces - 689B】Mike and Shortcuts(Dijkstra最短路,或者bfs跑状态类似spfa)

题干: Recently, Mike was very busy with studying for exams and contests. Now he is going to chill a bit by doing some sight seeing in the city. City consists of n intersections numbered from 1 to n. Mike starts walking from his house located a…

java utf-8 gbk_Java 字符转码之UTF-8转为GBK/GB2312

java跟python类似的做法,在java中字符串的编码是java修改过的一种Unicode编码,所以看到java中的字符串,心理要默念这个东西是java修改过的一种Unicode编码的编码。packagestring;importjava.nio.charset.Charset;public classUTF82GBK {publi…

java好的博客_推荐5个万博爆款Java开源博客,是我目前用过最好用的博客系统

1.OneBlog一个简洁美观、功能强大并且自适应的Java博客,使用springboot开发,前端使用Bootstrap,支持移动端自适应,配有完备的前台和后台管理功能。功能简介多种编辑器、自动申请友情链接、百度推送、评论系统、权限管理、SEO、实时…

中介者模式java_图解Java设计模式之中介者模式

智能家庭项目1)智能家庭包括各种设备,闹钟、咖啡机、电视机、窗帘等2)主人要看电视时,各个设备可以协同工作,自动完成看电视的准备工作,比如流程为 :闹铃响起 - 》咖啡机开始做咖啡 -》窗帘自动落下 -》电视机开始播放…

【POJ - 2398】Toy Storage (计算几何,二分找位置,叉积,点和直线的位置关系)

题干: Mom and dad have a problem: their child, Reza, never puts his toys away when he is finished playing with them. They gave Reza a rectangular box to put his toys in. Unfortunately, Reza is rebellious and obeys his parents by simply throwing …

java servlet 转发和重定向_JavaWeb(一)Servlet中乱码解决与转发和重定向的区别

前言前面其实已经把Servlet中所有的内容都介绍完了,这篇讲补充一点乱码和重定向与转发之间的区别!一、request请求参数出现乱码问题1.1、get请求1)乱码示例get请求的参数是在url后面提交过来的,也就是在请求行中。结果:Servlet_de…

java jsp导出pdf文件_JSP页面导出PDF格式文件

JSP页面导出PDF格式文件基本在前端页面可以全部完成添加下载链接的点击事件var downPdf document.getElementById("downLoad");downPdf.onclick function() {downPdf.parentNode.removeChild(downPdf);html2canvas(document.body, {onrendered:function(canvas) {v…

java unsafe park_Java中Unsafe类详解

http://www.cnblogs.com/mickole/articles/3757278.htmlJava不能直接访问操作系统底层,而是通过本地方法来访问。Unsafe类提供了硬件级别的原子操作,主要提供了以下功能:1、通过Unsafe类可以分配内存,可以释放内存;类中…

【qduoj - 夏季学期创新题】骑士游历(递推dp)

题干: 描述 输入 输入包含多组数据,第一行T表示数据组数接下来每行六个整数n,m,x1,y1,x2,y2(分别表示n,m,起点坐标,终点坐标) 输出 输出T行,表示…