对跨多个表格的数据组合时需要用到的SQL

作者:茶晶 时间:2009-01-06 11:18:00 

在对跨多个表格的数据进行组合时,有时很难搞清楚要使用哪一个SQL句法。我将在这里对将多个表格中的查询合并至单一声明中的常用方式进行阐述。

在这篇文章中的样本查询符合SQL92 ISO标准。不是所有的数据库生产商都遵循这项标准,而且很多厂商采取的提升措施会带来一些意料不到的后果。如果你不确定你的数据库是不是支持这些标准,你可以参看生产厂商的有关资料。

SELECT

一个简单的SELECT声明就是查询多个表格的最基本的方式。你可以在FROM子句中调用多个表格来组合来自多个表格的结果。这里是一个它如何工作的实例:

SELECT table1.column1, table2.column2 FROM table1,

table2 WHERE table1.column1 = table2.column1;

这个实例中,我使用点号(table1.column1)来指定专栏来自哪一个表格。如果所涉及的专栏只在一个参考的表格中出现,你就不需要加入完整的名称,但是加入完整名称会对可读性起到帮助。

在FROM子句中表格之间由逗号来分隔,你可以加入所需的任意多的表格,尽管一些数据库有一个在引入正式的JOIN声明之前他们可以有效地处理的内容这方面的限制,这个将在下面谈到。

这个句法是一个简单的INNER JOIN。一些数据库将它看成与一个外部的JOIN是等同的。WHERE子句告知数据库哪一个区域要做关联,而且它返回结果时,就像列出的表格在给定的条件下组合成一个单独的表格一样。值得注意的是,你的比较条件并不需要与你作为结果组返回的专栏相同。在上面的例子中,table1.column1和table2.column1用来组合表格,但是返回的却是table2.column2。

你可以在WHERE子句中使用AND关键字来将这个功能扩展至多于两个的表格。你还可以使用这样的表格组合来限制你的结果而不用实际地从每个表格返回专栏。在下面的例子中,table3与table1匹配,但是我没有从table3返回任何东西来显示。我只是确保来自table1的有关专栏存在于table3之中。注意此例中table3需要在FROM子句中被引用。

SELECT table1.column1, table2.column2 FROM table1,

table2, table3 WHERE table1.column1 =

table2.column1 AND table1.column1 = table3.column1;

然而,要注意的是,这个查询多个表格的方式是一个暗指的JOIN。你的数据库可能对事物进行不同的处理,这取决于它所使用的优化引擎。而且,忽略对与WHERE子句的相关特性的定义将会给你带来不愿看到的结果,例如从余下的查询中返回与每一个可能的结果相关的专栏的rogue域,就像在CROSS JOIN之中一样。

如果你习惯于你的数据库处理这种类型的声明的方式,且你只对两个或是少数几个表格进行组合,一个简单的SELECT声明就可以达到目的。

JOIN

JOIN的工作方式与SELECT声明是相同的,它从不同的表格中返回一个带有专栏的结果组。在暗含的JOIN之上使用外部JOIN的优势是对你的结果组的更好的控制,而且还可能在涉及很多个表格的情况下提升性能表现。

标签:
0
投稿

猜你喜欢

  • 四种方法在SQL Server数据库中成批导入数据

    2009-02-19 17:25:00
  • ASP中Global.asa使用方法说明

    2007-11-03 13:18:00
  • asp如何对一个文件夹进行创建和删除?

    2009-11-20 18:42:00
  • MYSQL教程:查询优化之调度和锁定

    2009-02-27 15:58:00
  • 用javascript实现Base64编码

    2008-03-04 16:51:00
  • 13个超酷的js显示时间效果

    2007-08-30 09:52:00
  • Flash真的适合做网站应用吗?

    2011-04-16 10:34:00
  • VBScript中的eval()函数

    2008-04-09 13:41:00
  • sqlserver通用的删除服务器上的所有相同后缀的临时表

    2012-06-06 20:07:34
  • 让字体美起来

    2011-06-14 09:50:21
  • MySQL中与NULL值有关的疑难问题

    2008-11-24 12:47:00
  • asp如何编写一个小数转换分数的函数?

    2009-11-08 19:01:00
  • vertical-align表单元素垂直对齐

    2009-07-27 13:02:00
  • 自己用的ASP分页函数

    2009-10-18 11:30:00
  • 布局篇(1)—If you love css …

    2008-04-16 14:14:00
  • asp封装dll源码分享

    2008-09-25 17:20:00
  • 百度百科中的asp词条:什么是asp

    2008-10-11 14:38:00
  • Asp测试网速代码(带进度条)

    2007-11-12 13:09:00
  • 15个梦幻的登录页面设计展示

    2009-07-19 14:17:00
  • 成为一个顶级设计师的第三准则

    2009-09-15 21:00:00
  • asp之家 网络编程 m.aspxhome.com