实现跨多个表格的数据进行组合的SQL语句 (1)
2011-10-17 16:56
232 查看
在对跨多个表格的数据进行组合时,有时很难搞清楚要使用哪一个SQL句法。我将在这里对将多个表格中的查询合并至单一声明中的常用方式进行阐述。 在这篇文章中的样本查询符合SQL92 ISO标准。不是所有的数据库生产商都遵循这项标准,而且很多厂商采取的提升措施会带来一些意料不到的后果。如果你不确定你的数据库是不是支持这些标准,你可以参看生产厂商的有关资料。 SELECT 一个简单的SELECT声明就是查询多个表格的最基本的方式。你可以在FROM子句中调用多个表格来组合来自多个表格的结果。这里是一个它如何工作的实例: 以下为引用的内容:
在FROM子句中表格之间由逗号来分隔,你可以加入所需的任意多的表格,尽管一些数据库有一个在引入正式的JOIN声明之前他们可以有效地处理的内容这方面的限制,这个将在下面谈到。 这个句法是一个简单的INNER JOIN。一些数据库将它看成与一个外部的JOIN是等同的。WHERE子句告知数据库哪一个区域要做关联,而且它返回结果时,就像列出的表格在给定的条件下组合成一个单独的表格一样。值得注意的是,你的比较条件并不需要与你作为结果组返回的专栏相同。在上面的例子中,table1.column1和table2.column1用来组合表格,但是返回的却是table2.column2。 你可以在WHERE子句中使用AND关键字来将这个功能扩展至多于两个的表格。你还可以使用这样的表格组合来限制你的结果而不用实际地从每个表格返回专栏。在下面的例子中,table3与table1匹配,但是我没有从table3返回任何东西来显示。我只是确保来自table1的有关专栏存在于table3之中。注意此例中table3需要在FROM子句中被引用。 以下为引用的内容:
如果你习惯于你的数据库处理这种类型的声明的方式,且你只对两个或是少数几个表格进行组合,一个简单的SELECT声明就可以达到目的。 JOIN JOIN的工作方式与SELECT声明是相同的,它从不同的表格中返回一个带有专栏的结果组。在暗含的JOIN之上使用外部JOIN的优势是对你的结果组的更好的控制,而且还可能在涉及很多个表格的情况下提升性能表现。 JOIN的类型有几种:LEFT,RIGHT,FULL OUTER,INNER和CROSS。你所使用的类型是由你想要看到的结果所决定的。例如,使用LEFT OUTER JOIN将会从列出的第一个表格中返回所有有关的行,而同时如果没有信息与第一个表格相关的话将潜在地从所列出的第二个表格中加入行。 |
相关文章推荐
- 实现跨多个表格的数据进行组合的SQL语句 (1)
- 实现跨多个表格的数据进行组合的SQL语句 (2)
- sql语句怎样实现求在列中选择某些相同名称的行,对这些相同名称行的数据进行累加.
- 一个sql语句同时实现两条数据的某个字段值交换
- 用SQL语句向表格中插入数据
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- sql语句实现随机取n条数据(转)
- 用SQL语句向表格中插入数据INSERT
- ASP.NET基础教程-使用CommandBuilder对象自动生成SQL语句对数据进行批量更新
- 导入外部数据+SQL语句的办法不支持参数查询,不过可以通过子查询进行模拟
- 利用临时数据表完成SQL语句输出并进行自动编号
- SQL 如何实现一条sql语句插入1000行数据
- 简单的实现分页获取数据的sql语句
- Mysql一条sql语句实现数据去重操作
- 用T-SQL语句实现SQL server与XLS,MDB等文件的数据交换
- sql语句实现一张表中插入另一张表数据
- SQL语句实现数据分页
- 【ORACLE】一个简单实用的对数据进行行列转换并统计的SQL语句
- T-SQL语句实现清空数据库数据的代码,保留原有表形式和各种约束
- 在不改sql语句和数据库表的情况下,使绑定到gridview中的数据进行换行