数据库是为更方便有效地管理信息而存在的人们,希望数据库可以随时提供所需要的数据信息。因此,对用户来说,数据查询是数据
库最重要的功能。本章将讲述数据查询的实现方法。
在数据库中,数据查询是通过SELECT 语句来完成的。SELECT 语句可以从数据库中
按用户要求检索数据,并将查询结果以表格的形式返回。我们在“Transact-SQL 语言”章
节及前面的章节中已经初步接触到了SELECT 语句的一些用法,在本章中将分类讲述其
具体用法。
本节讲述SELECT 语句完整的语法结构,这是一个非常冗长、枯燥的过程。读者可
以跳过本节,从第二节开始阅读,而将本节作为理解、编写查询语句的语法参考资料。
SELECT 语句完整的语法结构如下:
SELECT statement ::=
<query_expression>
} ]
] ]
}
) ]
<query expression> ::=
{ <query specification> | (<query expression>) }
<query specification | (<query expression>) ]
<query specification> ::=
SELECT
]
<select_list>
]
group_by_expression
]
由于SELECT 语句特别复杂,上述结构还不能完全说明其用法,因此我们将它拆分为若干部分来讲述。
10.1.1 SELECT 子句
SELECT 子句指定需要通过查询返回的表的列,其语法如下:
SELECT
]
<select_list>
<select_list> ::=
{ *
| { table_name | view_name | table_alias }.*
| { column_name | expression | IDENTITYCOL | ROWGUIDCOL }
column_alias ]
| column_alias = expression
}
各参数说明如下:
ALL
指明查询结果中可以显示值相同的列。ALL 是系统默认的。
DISTINCT
指明查询结果中如果有值相同的列,则只显示其中的一列。对DISTINCT 选项来说,
Null 值被认为是相同的值。
TOP n
指定返回查询结果的前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 子句(有关游标的介绍请
参见“游标和视图”章节)。
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>}
<table_source> ::=
table_name table_alias ] ) ]
| view_name table_alias ]
| rowset_function table_alias ]
| OPENXML
| derived_table table_alias ) ]
| <joined_table>
<joined_table> ::=
<table_source> <join_type> <table_source> ON <search_condition>
| <table_source> CROSS JOIN <table_source>
| <joined_table>
<join_type> ::=
} ]
JOIN
各参数说明如下:
table_source
指明SELECT 语句要用到的表、视图等数据源。
table_name table_alias ]
指明表名和表的别名。
view_name table_alias ]
指明视图名称和视图的别名。
rowset_function table_alias ]
指明行统计函数和统计列的名称。
OPENXML
提供一个XML 文档的行集合视图。
WITH ( )
指定一个或多个表提示。通常SQL Server 的查询优化器会自动选取最优执行计划,
除非是特别有经验的用户,否则最好不用此选项。关于表提示table_hint 的设,定请参见
下一章的“删除数据”部分。
derived_table table_alias
指定一个子查询,从数据库中返回数据行。
column_alias







评论列表