一、 简单查询 f. =4p^
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的表或视图、以及搜索条件等。 w%k)J{\
hoi hdVjv
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 97Qng*i
Sn/~R|3XA7
SELECT nickname,email TUEEwDK-
FROM testtable '.@R_sj
WHERE name='张三' j]<T\O>t>
0\jOg
(一) 选择列表 3Fn26Rij
7
v<$l
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变量和全局变量)等构成。 szwXr
K`FgU7g{
1、选择所有列 ^[CD- #
%f&(U/
例如,下面语句显示testtable表中所有列的数据: morI'6N
|pp @
SELECT * HJ5m5':a
FROM testtable lq_W;L
T}[W')[s
2、选择部分列并指定它们的显示次序 As (C8C<
h& (@gU`A
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 2`vCQV
Q[p0bD:
例如: C<fNIc~.
)B*?se]LJ
SELECT nickname,email bYdC.AE
FROM testtable vd /_`l.D
KX)xCR~
3、更改列标题 4W.;p"S2
%`}CbD6
在选择列表中,可重新指定列标题。定义格式为: uPV,-rm[F_
Z=!*7@QY
列标题=列名 !r.}y|t?;
列名 列标题 @WEem(@
ojVpw4y.
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列标题: =,[46 ;q
4_N)1u !
SELECT 昵称=nickname,电子邮件=email ja7Zv[
FROM testtable %TG$5')0
4、删除重复行 q 'hV 'U
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 <'~8mV1
vtmO
5、限制返回的行数 Mn~A;=%qF
!nj%n
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是表示一百分数,指定返回的行数等于总行数的百分之几。 \MtiLaI"
~~zw[#'
例如: ! qcu-d5b
9v
cUo?/
SELECT TOP 2 *
|k/; .
FROM testtable ]QT0sGl
SELECT TOP 20 PERCENT * ;*W]]4fy
FROM testtable sp**Sg)
g@Ni!U"_c
(二)FROM子句 ITc/aX
aG}9Z8D
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图,它们之间用逗号分隔。 4!k={Pd
EkSTN
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应使用下面语句格式加以限定: mZ;yk(
cfeX(0
SELECT username,citytable.cityid +X*`}-3
FROM usertable,citytable FYcMvY
WHERE usertable.cityid=citytable.cityid ZVp\5V*
在FROM子句中可用以下两种格式为表或视图指定别名: 7Xad2wXn
iY|YEi8
表名 as 别名 qfSoF|
表名 别名 fSqbGoIQ
3Gp4%UT&
(二) FROM子句 b=|&0B$E
|}M']Vz
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图,它们之间用逗号分隔。 M?cKt.t
K%=n \Y
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应使用下面语句格式加以限定: 0dcXgP
{my=Li<