网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.[SQLServer2000]TEMPDB丢失或TEM.
.Sql Server下数据库链接的使用方.
.怎样缩小SQL Server数据库日志文.
.SQL Server 2005返回刚刚插入的数.
.讲解无法打开用户默认数据库的解.
.三步堵死SQL注入漏洞.
.如何获取指定表中指定字段内的可.
.SQL语句导入导出大全.
.在SQL Server2005中用语句创建数.
.sql server 查询分析器快捷键集合.
.从数据库中随机抽N条记录.
.使用VS 2005和SQL Server 2005创.
.SQL Server数据库超级管理员账号.
.如何删除数据库中的冗余数据(翻.
.实现按部门月卡余额总额分组统计.
.高级自定义查询、分页、多表联合.
.如何获取SQL Server数据库里表的.
.在SQLServer中怎么样恢复数据的存.
.SQL Server 2005中利用xml拆分字.
.数据库升迁从sqlserver6.5到sqls.

怎样使用 SQL Server 数据库嵌套子查询

发表日期:2007-12-3


  很多SQL Server程序员对子查询(subqueries)的使用感到困惑,尤其对于嵌套子查询(即子查询中包含一个子查询)。现在,就让我们追本溯源地探究这个问题。

  有两种子查询类型:标准和相关。标准子查询执行一次,结果反馈给父查询。相关子查询每行执行一次,由父查询找回。在本文中,我将重点讨论嵌套子查询(nested subqueries)(我将在以后介绍相关子查询)。

  试想这个问题:你想生成一个卖平垫圈的销售人员列表。你需要的数据分散在四个表格中:人员.联系方式(Person.Contact),人力资源.员工(HumanResources.Employee),销售.销售订单标题(Sales.SalesOrderHeader),销售.销售订单详情(Sales.SalesOrderDetail)。在SQL Server中,你从内压式(outside-in)写程序,但从外压式(inside-out)开始考虑非常有帮助,即可以一次解决需要的一个语句。

  如果从内到外写起,可以检查Sales.SalesOrderDetail表格,在LIKE语句中匹配产品数(ProductNumber)值。你将这些行与Sales.SalesOrderHeader表格连接,从中可以获得销售人员IDs(SalesPersonIDs)。然后使用SalesPersonID连接SalesPersonID表格。最后,使用ContactID连接Person.Contact表格。

以下是引用片段:
  USE AdventureWorks ;
  GO
  SELECT DISTINCT c.LastName, c.FirstName
  FROM Person.Contact c JOIN HumanResources.Employee e
  ON e.ContactID = c.ContactID WHERE EmployeeID IN
  (SELECT SalesPersonID
  FROM Sales.SalesOrderHeader
  WHERE SalesOrderID IN
  (SELECT SalesOrderID
  FROM Sales.SalesOrderDetail
  WHERE ProductID IN
  (SELECT ProductID
  FROM Production.Product p
  WHERE ProductNumber LIKE'FW%')));
  GO


  这个例子揭示了有关SQL Server的几个绝妙事情。你可以发现,可以用IN()参数替代SELECT 语句。在本例中,有两次应用,因此创建了一个嵌套子查询。

  我是标准化(normalization)的发烧友,尽管我不接受其荒谬的长度。由于标准化具有各种查询而增加了复杂性。在这些情况下子查询就显得非常有用,嵌套子查询甚至更加有用。

  当你需要的问题分散于很多表格中时,你必须再次将它们拼在一起,这时你可能发现嵌套子程序就很有用。

上一篇:SQL Server 2005支持的两条新语法 人气:1957
下一篇:解析SQL Server 的存储过程 人气:2789
浏览全部SQL Server的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐