60度 Eadren 网络 >> 设计教程 >> 数据库开发 >> Mssql教程 >> 正文[打印] [收藏] 

数据查询--SELECT语句


作者:生鱼片 文章来源:互联网 点击数: 更新时间:2006-4-15 12:42:25


    数据库是为更方便有效地管理信息而存在的人们,希望数据库可以随时提供所需要的数据信息。因此,对用户来说,数据查询是数据
库最重要的功能。本章将讲述数据查询的实现方法。

在数据库中,数据查询是通过SELECT 语句来完成的。SELECT 语句可以从数据库中 按用户要求检索数据,并将查询结果以表格的形式返回。我们在“Transact-SQL 语言”章 节及前面的章节中已经初步接触到了SELECT 语句的一些用法,在本章中将分类讲述其 具体用法。

本节讲述SELECT 语句完整的语法结构,这是一个非常冗长、枯燥的过程。读者可 以跳过本节,从第二节开始阅读,而将本节作为理解、编写查询语句的语法参考资料。 SELECT 语句完整的语法结构如下:
SELECT statement ::=
<query_expression>
[ ORDER BY { order_by_expression | column_position [ ASC | DESC ] } [,...n] ]
[ COMPUTE { { AVG | COUNT | MAX | MIN | SUM } (expression) } [,...n]
[ BY expression [,...n] ] ]
[ FOR { BROWSE | XML { RAW | AUTO | EXPLICIT }
[ , XMLDATA ]
[ , ELEMENTS ]
[ , BINARY base64 ] }
[ OPTION (<query_hint> [,...n]) ]
<query expression> ::=
{ <query specification> | (<query expression>) }
[UNION [ALL] <query specification | (<query expression>) [...n] ]
<query specification> ::=
SELECT [ ALL | DISTINCT ]
[ {TOP integer | TOP integer PERCENT} [ WITH TIES] ]
<select_list>
[ INTO new_table ]
[ FROM {<table_source>} [,...n] ]
[ WHERE <search_condition> ]
[ GROUP BY [ALL] group_by_expression [,...n]
[ WITH { CUBE | ROLLUP } ] ]
[ HAVING <search_condition> ]
由于SELECT 语句特别复杂,上述结构还不能完全说明其用法,因此我们将它拆分为若干部分来讲述。

10.1.1 SELECT 子句
SELECT 子句指定需要通过查询返回的表的列,其语法如下:
SELECT [ ALL | DISTINCT ]
[ TOP n [PERCENT] [ WITH TIES] ]
<select_list>
<select_list> ::=
{ *
| { table_name | view_name | table_alias }.*
| { column_name | expression | IDENTITYCOL | ROWGUIDCOL }
[ [AS] column_alias ]
| column_alias = expression
} [,...n]
各参数说明如下:

  • ALL
    指明查询结果中可以显示值相同的列。ALL 是系统默认的。
  • DISTINCT
    指明查询结果中如果有值相同的列,则只显示其中的一列。对DISTINCT 选项来说, Null 值被认为是相同的值。
  • TOP n [PERCENT]
    指定返回查询结果的前n 行数据。如果PERCENT 关键字指定的话,则返回查询结果 的前百分之n 行数据。
  • WITH TIES
    此选项只能在使用了ORDER BY 子句后才能使用当指定此项时,除了返回由TOP n (PERCENT) 指定的数据行外,还要返回与TOP n (PERCENT) 返回的最后一行记录中 由ORDER BY 子句指定的列的列值相同的数据行。
  • select_list
    select_list 是所要查询的表的列的集合,多个列之间用逗号分开。
  • * 通配符,返回所有对象的所有列。
  • table_name | view_name | table_alias.*
    限制通配符*的作用范围。凡是带*的项,均返回其中所有的列。
  • column_name
    指定返回的列名
  • expression
    表达式可以为列名、常量、函数或它们的组合。
  • IDENTITYCOL
    返回IDENTITY 列。如果FROM 子句中有多个表含有IDENTITY 列,则在IDENTTYCOL 选项前必须加上表名,如Table1.IDENTITYCOL。
  • ROWGUIDCOL
    返回表的ROWGUIDCOL 列。同IDENTITYCOL 选项相同,当要指定多个ROWGUIDCOL 列时,选项前必须加上表名,如Table1. ROWGUIDCOL。
  • column_alias
    在返回的查询结果中用此别名替代列的原名。column_alias 可用于ORDER BY 子句, 但不能用于WHERE GROUP BY 或HAVING 子句如果查询是游标声明命令DECLARE CURSOR 的一部分,则column_alias 还不能用于FOR UPDATE 子句(有关游标的介绍请 参见“游标和视图”章节)。

10.1.2 INTO 子句
INTO 子句用于把查询结果存放到一个新建的表中。SELECT...INTO 句式不能与COMPUTE 子句一起使用。其语法如下:
INTO new_table
参数new_table 指定了新建的表的名称。新表的列由SELECT 子句中指定的列构成,新表中的数据行是由WHERE 子句指定的。但如果SELECT 子句中指定了计算列,在新表中对应的列则不是计算列,而是一个实际存储在表中的列,其中的数据由执行SELECT...INTO 语句时计算得出。如果数据库的“Select into/bulk copy” 选项设置为“True/On”,则可以用INTO 子句创建表和临时表,反之,则只能创建临时表。

10.1.3 FROM 子句
FROM 子句指定需要进行数据查询的表。只要SELECT 子句中有要查询的列,就必须使用FROM 子句。其语法如下:
FROM {<table_source>} [,...n]
<table_source> ::=
table_name [ [AS] table_alias ] [ WITH ( <table_hint> [,...n]) ]
| view_name [ [AS] table_alias ]
| rowset_function [ [AS] table_alias ]
| OPENXML
| derived_table [AS] table_alias [ (column_alias [,...n] ) ]
| <joined_table>
<joined_table> ::=
<table_source> <join_type> <table_source> ON <search_condition>
| <table_source> CROSS JOIN <table_source>
| <joined_table>
<join_type> ::=
[ INNER | { { LEFT | RIGHT | FULL } [OUTER] } ]
[ <join_hint> ]
JOIN
各参数说明如下:

  • table_source
    指明SELECT 语句要用到的表、视图等数据源。
  • table_name [ [AS] table_alias ]
    指明表名和表的别名。
  • view_name [ [AS] table_alias ]
    指明视图名称和视图的别名。
  • rowset_function [ [AS] table_alias ]
    指明行统计函数和统计列的名称。
  • OPENXML
    提供一个XML 文档的行集合视图。
  • WITH ( [,...n])
    指定一个或多个表提示。通常SQL Server 的查询优化器会自动选取最优执行计划, 除非是特别有经验的用户,否则最好不用此选项。关于表提示table_hint 的设,定请参见 下一章的“删除数据”部分。
  • derived_table [AS] table_alias
    指定一个子查询,从数据库中返回数据行。
  • column_alias
    指明列的别名,用以替换查询结果中的列名。
  • joined_table
    指定由连接查询生成的查询结果。有关连接与连接查询的介绍参见本章的相关章节。
  • join_type
    指定连接查询操作的类型。
  • INNER
    指定返回两个表中所有匹配的行。如果没有join_type 选项,此选项就为系统默认。
  • LEFT [OUTER]
    返回连接查询左边的表中所有的相应记录,而右表中对应于左表无记录的部分,用NULL 值表示。
  • RIGHT [OUTER]
    返回连接查询右边的表中所有的相应记录,而左表中对应于右表无记录的部分,用NULL 值表示。
  • FULL [OUTER]
    返回连接的两个表中的所有记录。无对应记录的部分用NULL 值表示。
  • join_hint
    指定一个连接提示或运算法则。如果指定了此选项,则INNER LEFT RIGHT 或FULL选项必须明确指定。通常

    [1] [2] [3]  下一页

    [1] [2] [3] 下一页

  • 上一篇教程:

  • 下一篇教程:
    • 相关 数据查询--SELECT语句 的文章:
      没有相关教程

    网友评论 

    数据载入中,请稍后……
    关于我们 | 免责声明 | 广告服务 | 版权隐私 | 联系我们 | 友情链接 | 网站地图 |