当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 深入浅出SQL教程之SELECT语句的自连接

MSSQL
开源MySQL公司停止提供企业版源代码tar包
细化解析:MySQL+Webmin轻松创建数据库
用mysql做站点时怎样记录未知错误的发生
SQL数据库操作类
如何利用SQL Server数据库快照形成报表
SQL Server中应当怎样得到自动编号字段
SQL Server数据库连接中常见的错误分析
详细讲解SQL Server数据库的文件恢复技术
轻松掌握SQL Server数据库的六个实用技巧
SQL Server数据库涉及到的数据仓库概念
深入了解SQL Server 2008 商业智能平台
剖析SQL Server 事务日志的收缩和截断
如何在不同版本的SQL Server中存储数据
怎样缩小SQL Server数据库的日志文件
SQL Server中两种修改对象所有者的方法
轻松掌握SQL Server存储过程的命名标准
怎样从旧版本SQL Server中重新存储数据
快速掌握如何使用SQL Server来过滤数据
教你快速掌握两个SQL Server的维护技巧
有效地使用 SQL事件探查器的提示和技巧

MSSQL 中的 深入浅出SQL教程之SELECT语句的自连接


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 96 ::
收藏到网摘: n/a

到目前为止,我们连接的都是两张不同的表,那么能不能对一张表进行自我连接呢?答案是肯定的。

  有没有必要对一张表进行自我连接呢?答案也是肯定的。

  表的别名:

  一张表可以自我连接。进行自连接时我们需要一个机制来区分一个表的两个实例。

  在FROM clause(子句)中我们可以给这个表取不同的别名, 然后在语句的其它需要使用到该别名的地方用dot(点)来连接该别名和字段名。

  我们在这里同样给出两个表来对自连接进行解释。

  爱丁堡公交线路,

  车站表:

  stops(id, name)

  公交线路表:

  route(num, company, pos, stop)

  一、对公交线路表route进行自连接。

SELECT * FROM route R1, route R2 WHERE R1.num=R2.num AND R1.company=R2.company

  我们route表用字段(num, company)来进行自连接. 结果是什么意思呢?

  你可以知道每条公交线路的任意两个可联通的车站。

  二、用stop字段来对route(公交线路表)进行自连接。

SELECT * FROM route R1, route R2 WHERE R1.stop=R2.stop;

  查询的结果就是共用同一车站的所有公交线。这个结果对换乘是不是很有意义呢。

  从这两个例子我们可以看出,自连接的语法结构很简单,但语意结果往往不是那么容易理解。就我们这里所列出的两个表,如果运用得当,能解决很多实际问题,例如,任意两个站点之间如何换乘。

SELECT R1.company, R1.num FROM route R1, route R2, stops S1, stops S2
WHERE R1.num=R2.num AND R1.company=R2.company AND R1.stop=S1.id AND R2.stop=S2.id
AND S1.name='Craiglockhart' AND S2.name='Tollcross'