文章主要描述的是SQL Server子查询,以及对SQL Server子查询概念的具体描述,SQL Server数据库的子查询主要是指将一条SQL Sever语句正确的嵌入到另一条SQL Sever数据库的语句中。数据库引擎将子查询做为虚表执行查询操作。
子查询可做为连接语句中的一个表,可做为选择语句中的一个值,也可以是SQL Sever查询子句,还可以是SQL Sever查询子句的字句,与数据操作语句混合在一起。
子查询的执行依赖于嵌套查询。查询树从最里层开始,一层一层向外执行。高层的嵌套查询可以访问低层嵌套查询的结果。
什么是相关子查询?
与经典子查询不同,相关子查询依赖于外部查询。外部查询和子查询是有联系的,尤其在子查询的WHERE语句中更是如此。相关子查询的工作方式是:在子查询中找到外部查询的参考时执行外部查询,此时将结果返回给子查询。然后在外部查询返回的结果集上执行SQL Server子查询操作。
相关子查询的执行性能
由于相关子查询中的子查询在外部查询返回的结果集上进行执行,其效率肯定下降。子查询的性能完全依赖于查询和有关的数据。但是,假如相关子查询的语句写得很有效率,则其执行性能能够胜过那些使用几个连接和临时表的程序。
一个示例
相关子查询的一个主要优点在于,它能完成传统SQL Sever查询不能解决的问题。例如,使用相关SQL Server子查询可以轻易完成这样的任务:获得连续的销售总计结果或每一个州中出售最多的商品。
下面的例子说明了如何使用相关子查询创建运行总计的过程。首先,运行下面的脚本创建一个例表:
CREATE TABLE SalesHistory (SaleID INT IDENTITY(1,1), Product VARCHAR(30), SaleDate *** ALLDATETIME, SalePrice MONEY )
现在,这个表保存了这些数据字段,让我们运行脚本程序向其中添加一些记录。Listing A中显示了向表中输入的300条记录的程序,其中SalePrice有些变化。虽然SalePrice的变化不大,但是也足以说明相关子查询如何工作。接下来,运行Listing B中的相关SQL Server子查询程序创建销售报表。
在报表中引入的连续的销售总计查询即是相关子查询。对于表中的每种产品,相关子查询重述了其结果集,并且在将结果返回到结果集之前,为每一种售出产品的SalePrice进行加和操作。
试一试
试着运行一下上面的例子,并且玩玩这些代码。对于我来说,可以从例子中学到很多新技术。假如已经精通了相关SQL Server子查询的原理,则可以考虑让自己进入数据库开发者的高层梯队。

上述的相关内容就是对在SQL Server子查询的描述,希望会给你带来一些帮助在此方面。
在Windows 7系统的默认设置中,当Windows 7系统处于休眠状态时,会同时断网的。如此一来,无论你正在使用迅雷还是快车等下载工具,同样可以在休眠状态下继续完成下载,最大限度做到从身边的小事开始支持环保。下面我们就详细介绍操作步骤,帮助Windows 7系统用户实现这一节能目标。 首先需要...
Windows 7 64位系统开机后提示"press any key to restart",无法进入系统了,具体现象如下所示: 故障分析: 故障的主要原因还是硬盘的问题,可以先检查是不是接触不良或坏了,进行修复或更换即可。 解决方法: 1、开机按F8不动到高级选项出现在松手,选“...
对于Windows 7系统来说,其默认安装的许多工具是我们很少使用或从来不用的,比如系统自带的扫雷、纸牌游戏等。删除此类长期不用的系统组件,不但可以让系统更清爽,更重要的是还可以提高系统的运行速度,特别是对于硬件配置相对较低的上网本来说,尤其如此。接下来,笔者就给大家介绍一下如何删除Windows...
北京时间1月13日消息,根据计划,微软将于2015年1月13日正式结束对Windows 7SP1的“主流支持”,而这也标志着“扩展支持”阶段的开始,这个阶段将于2020年1月14日结束。 2013年10月份,微软终止销售独立的Windows 7系统安装包,并要求制造商于2014年10月份停止生...
解决方法: 其实处理这些使用流氓软件,需要将相关的.exe文件删除,使它不能再运行,或者直接清除这个服务本身,使计算机重启的时候,它不会再启动。比如Hijackthis扫描,在扫描日志中,一般会把非Windows系统的服务以023的方式列出来,如下面这段: O23 - ...
故障分析: 主要原因应该是不存在软盘驱动器或驱动器未安装,找到故障原因后,Windows 7 32位系统只要将软盘驱动器禁用就可以了。 解决措施: 1、右键点击计算机,选择管理,打开计算机管理窗口; 2、在计算机管理中,找到设备管理器,在右边的软盘控制器中右击,选择卸载即可。 以...