


版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、,查询失查询块order bysql语法相关子查询与非相关子查询1 :标量子查询(相对于多值子查询):只有标量子查询返回的是单个记录或者不返回,就是有效的子查询。Ex1:select Orderld From Orders where Employeeld=(select EmployeeId From employees where lastName like NDavolio)将Davolio 改为D%时,这个时候子查询中返回结果为2行,等号右边此时为多值败将=改为in谓词.查询才能通过.employees 表中无 lastname= jason ,夕卜部查询将返回 nuII.2:非相关子
2、查询(嵌套子查询)一个 select.From.Where查询语句块可以嵌套在另一个select.From.Where的Where子句中,称为嵌套查询。外层查询称为父查询,主查询。内层查询称为子查询,从查询。子查询可以嵌套多层,子查询查询到的结果又成为父查询的条件。子查询中不能有分组语句。先处理子查询,再处理父查询。细分如下:1。简单嵌套查询查询选修课程号为101并且成绩高于学生号为9501101的所有学生的成绩select * from sclasswhere eno=101 and degree=(select degree from sclass where sno=9501101a n
3、d eno=101)当子查询跟随在 =、!=、=、=之后,子查询的返回值只能是一个,否则应在外层where子句中用一个in限定符,即要返回多个值,要用 in或者not in2。 带n ot in的嵌套查询只要主查询中列或运算式是在(不在)子查询所得结果列表中的话, 则主查询的结果为我们要的数据select sales_id,tot_amtfrom saleswhere sale _idin (select saled from employee where sex=F)where sno not in( Select dist inct sno from sclass)3。带exists 的嵌
4、套查询子查询的结果至少存在一条数据时,则主查询的结果为我们要的数据。(exists )或自查询的结果找不到数据时,则主查询的结果为我们要的数据(n ot exists)我们经常查询的两个表有多少重复的记录就用这个以下范例让你找出滞销的产品,也就是尚未有任何销售记录的库存产品。此范例主要是查询以库文件中的每一条产品代码到销售明细表中去查询,如果查询不到任何一条,表示该产品未曾卖出任何一件。select * from stock awhere not exists(select * from sale_item bwhere d_id=d_id anda.stup_id=b.s
5、tup_id)4。select . where列或运算式比较运算运算【any|all(子查询)只要主查询中列或运算式与子查询所得结果中任一(any)或全部(all )数据符合比较条件的话则主查询的结果为我们要的数据select sale_id,tot_amtfrom saleswhere tot_amta ny (select tot_amt from sales where sale_id=e0013a nd order_date=1996/11/10)选出不同的人金额最高的订单select * from sales awhere tomat=(select max(totmat) from
6、 saleswhere n ame=a .n ame)3:相关子查询(多值子查询)1非相关子查询是独立于外部查询的子查询,子查询总共执行一次,执行完毕后将值传递给外部查询。2相关子查询的执行依赖于外部查询的数据,外部查询执行一行,子查询就执行一次。查询中再查询,通常是以一个查询作为条件来供另一个查询使用例:有work表和部门表A:检索出在部门表中登记的所有部门的职工基本资料select * from work where 咅部门编号 in not in(select咅部门编号 fromdbo.部门)B:检索出在work表中每一个部门的最高基本工资的职工资料select * from work
7、a where 基本工资=(select max(基本工资)from work b where a.部门名称=b.部门名称)说明:由外查询提供一个部门名称给内查询,内查询利用这个部门名称找到该部门的最高基本工资,然后外查询根据基本工资判断是否等于最高工资,如果是的,则显示出来.相当于:select * from work,(select部门名称,max(基本工资)as 基本工资from work group by咅咅门名称 as t) where work. 基本工资 =t.基本工资 and work.部门名称=t.部门名称C:用嵌套work表和嵌套部门表,在嵌套work表中检索出姓名和职工号
8、都在嵌套部门存在的职工资料select * from 嵌套 work where 职工号 in (select 职工号 from 嵌套部门)and姓名in (select 姓名from 嵌套部门)察看结果,分析原因(错误,因为这 两个in不是一对一改:select * from 嵌套 work a,嵌套部门b where a.职工号=b.职工号and a.姓名=b.姓名改:select * from 嵌套 work where 职工号=(select 职工号 from 嵌套部门)and姓名=(select 姓名from 嵌套部门)行吗?为什么,分析原因?不能后面的 select得到的结果不是一
9、个值而又跟在=后必然出错在嵌套中使用exists关键字存在例:1:用嵌套work表和嵌套部门表,在嵌套work表中检索出姓名和职工号都在嵌套部门存在 的职工资料嵌套部门b where a.部门where部门.部门编部门where 部门.select * from 嵌套 work a where exists (select * from 姓名=b.姓名and a.职工号=b.职工号)2:在work表检索出在部门表没有的职工select * from work where not exists (select * from号=work.部门编号)能否改成:select * from work w
10、here exists (select * from部门编号work.部门编号)是不能的,在列清单中使用 select例:1:在workl表和部门表中检索出所有部门的部门名称和基本工资总和select 部门名称(select sum( 基本工资)from workl b where a.部门编号=b.部门编号)from 部门a2:检索各部门的职工人数select 部门编号,部门名称(select count( 职工号)from workl a where a. 部门编 号=b.部门编号)as 人数from 部门b3:在商品表和销售表中查询每一职工的姓名,所属部门,销售总量select 姓名,所
11、属部门(select sum( 销售量)from 商品销售a where a. 职工号=b. 职工号)as销售总量from嵌套部门b说明:都是相关子查询的特殊情况,外层的查询是内层查询的条件如:a.职工号=b.职工号,内层条件成立则得到的些行记录是并入外层查询的最终结果,否则不记录入最后结果许多查询都可以通过执行一次子查询并将得到的值代入外部查询的WHERE子句中进行计算。在包括相关子查询(也称为重复子查询)的查询中,子查询依靠外部查询获得值。这意味着子查询是重复执行的,为外部查询可能选择的每一行均执行一次。此查询在Salesperson 表中检索奖金为 5000且雇员标识号与 Employe
12、e和Salesperson 表中的标识号相匹配的雇员的名和姓的一个实例。USE Adve ntureWorks2008R2;GOSELECT DISTINCT c.LastName, c.FirstName,e.Bus in essE ntitylD FROM Perso n.Person AS c JOIN Huma nResources.Employee AS eONe.Busi nessE ntitylD = c.Busi nessE ntitylD WHERE 5000.00 IN(SELECTBon usFROM Sales.SalesPerson spWHERE e.Busi ne
13、ssE ntitylD =sp.Bus in essE ntitylD) ;GO下面是结果集:LastName FirstName Busin essE ntitylDAn sma n-Wolfe Pamela 280Saraiva Jos e282(2 row(s) affected)该语句中前面的子查询无法独立于外部查询进行计算。它需要Employee.BusinessEntitylD值,但是此值随 SQL Server 检查Employee中的不同行而改变。下面准确说明了如何计算此查询:SQL Server通过将每一行的值代入内部查询,考虑Employee表中的每一行是否都包括在结果中。
14、例如,如果SQL Server首先检查 Syed Abbas行,那么变量 Employee.BusinessEntitylD将取值285 , SQLServer将该值代入内部查询。USE Adve ntureWorks2008R2;GOSELECT Bon usFROM Sales.SalesPers onWHERE Busi nessE ntitylD = 285;结果为0 (Syed Abbas没有收到奖金,因为他不是销售人员),因此外部查询计算为:USE Adve ntureWorks2008R2;GOSELECT LastName, FirstNameFROM Perso n.P erson AS cJOIN HumanResources.Employee AS eONe.BusinessEntitylD= c.BusinessEntitylDWHERE5000 IN (0.00)引用外部查询列的子查询。逻辑上讲,子查询会为外部查询的每行计算一次。Ex4:查询每个员工employee最近的一个订单最大订单日期和 Max(Orderld)最大订From Orders As o1 where OrderDate=思路:-需要附加属性(Tiebreaker)Max(OrderDate)单号来确定每名员工的最近订单状况select Orderld,Customerld,Em
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 黔南州2024-2025学年度第一学期期末质量监测 物理
- 2024年甘肃省嘉峪关市金川区三年级数学第一学期期末达标检测试题含解析
- 《化工工艺》课件
- 规范乘车安全教育
- 财务共享模式下的审核机制试题及答案
- 2025年污水自动采样器合作协议书
- 看病流程简笔画
- 营销活动管理控制体系
- 甘肃省部分学校2024-2025学年高一下学期期中联考地理试卷(含答案)
- Unit 6(单元测试)-2024-2025学年八年级英语下册 人教版
- 初二地理考试试题及答案
- 2024年阿坝州黑水县招聘社区工作者考试真题
- 内镜洗消相关试题及答案
- 2024年中国铁路国际有限公司招聘真题
- 石油化工阀门检修及维护措施
- 2024年广西物流职业技术学院招聘教职人员笔试真题
- 2024-2025湘科版小学科学四年级下册期末考试卷及答案(三套)
- 大型海上发电用双燃料燃气轮机企业数字化转型与智慧升级战略研究报告
- 工程承包再转让合同协议
- (广东二模)2025年广东省高三高考模拟测试(二)历史试卷(含答案)
- 2025湖南建投集团春季校园招聘239人笔试参考题库附带答案详解
评论
0/150
提交评论