一、简单查询
9CCkqB/
4%1D}9hO6
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 z>w`ZD}XY
0\2\*I}?
表或视图、以及搜索条件等。 V/LQ<Yke
RT>{*E<I
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 U%h);!<
xQw7 :18wQ
SELECT nickname,email V7TVt,-3
WD'#5]#Y
FROM testtable N{-]F|XX
8ssJ<LP
WHERE name='张三' c\% r38
"zIFxDR#
(一)选择列表 ?BhMjsy.
P>9aI/d9
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 WcC?8X2
JWA@+u*k
量和全局变量)等构成。 p$ bnK]
[frq
'c
1、选择所有列 B75k^ohfj
M)sZSH.<O
例如,下面语句显示testtable表中所有列的数据: 3pmWDG6L
MLFKH
SELECT * 0(_l|PScF
>a3p >2
FROM testtable V5 U?F6
vSonkJ_
2、选择部分列并指定它们的显示次序 :_Eqf8T
Jk0r&t7
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 pIbdN/z
nYbhy}y
例如: aTf`BG{kw
pHoEa7:
SELECT nickname,email 4nAa`(62
7} jWBK
FROM testtable :{(w3<i
$<ld3[l i
3、更改列标题 ~^+0
.Vq)zi1<
在选择列表中,可重新指定列标题。定义格式为: ]tY
^0a
Dde]I_f}
列标题=列名 r=c<--_@
N25V]
列名 列标题 Qv-@Zt!8
97)/"i e
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 ." $
jF[ 1za
标题: HNL42\Kz!
f{0F|w<gf
SELECT 昵称=nickname,电子邮件=email GU Q{r!S
5s?Hxn
FROM testtable _{jjgQJ5
eSW{Cb
4、删除重复行 $`Ix:gi
M@W[Bz
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 _w*}\~`=^
I5h[%T
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 xAggn
@]bPVG?d
5、限制返回的行数 2S' {!A
_j_x1.l
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 -|rLs$V1r
!;_H$r0
表示一百分数,指定返回的行数等于总行数的百分之几。 `-3o+ID\
_4 cvX
例如: <_(/X,kBK
qF iLh9=D
SELECT TOP 2 * R>`}e+-D
.Yw'oYnS
FROM testtable $4MrP$4TI
@Tfl>/%
SELECT TOP 20 PERCENT * >c-fI$]
E\; ikX&1
FROM testtable +/D>|loRC
>3u]OSb
(二)FROM子句 Dz./w
Q?AmOo-a
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, N$[$;Fm:
lgpW@g
它们之间用逗号分隔。 9Ct`
ud fe
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 ddVa.0Z!<
G^"Vo x4
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 KN"S?i]X
eiJ2NwR\w
使用下面语句格式加以限定: wM_c48|d
hXGwP4
SELECT username,citytable.cityid /*Qq[C
>M Jg ,
FROM usertable,citytable LW:o8ES33
M/Pme&%
WHERE usertable.cityid=citytable.cityid "n:{!1VGw
6oSQQhge
在FROM子句中可用以下两种格式为表或视图指定别名: c%*($)#
h d~$WV0#
表名 as 别名 wv^rS^~
4.RG4Jq
表名 别名 ~XeFOMq
a}Sd W
例如上面语句可用表的别名格式表示为: PA w-6;
,<DB&&EV8
SELECT username,b.cityid (z$r :p
!A1)|/a@
FROM usertable a,citytable b 'Pvm8t
- y9>;6
WHERE a.cityid=b.cityid Q!,<@b)
$;G{Pyp
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 /=uMk]h
r}yG0c,
例如: %r)avI
fFjH "2WD
SELECT a.au_fname+a.au_lname Il.Ed-&62
P6,7]6bp
FROM authors a,titleauthor ta j]0^y}5f+s
HyiFy7j
(SELECT title_id,title .}')f;jH5<
6mH/ m&
FROM titles 4x%(9_8{-
kX:tc
WHERE ytd_sales>10000 n]+W 3[i
^w~23g.
) AS t 9;%CHb&
*c[2C
WHERE a.au_id=ta.au_id
_if|TFw;h
{2`=qt2
AND ta.title_id=t.title_id D\/xu-&
NrDi
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 >\ST-7[^L
B5X sGLV
(三)使用WHERE子句设置查询条件 ~"Gf<3^y+
d7Ur$K\=y
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: FZiW|G
A|}l)!%
SELECT * )Z+{|^`kJ
2}?wYI*:5|
FROM usertable I &* _,d
YJxw 'U
>P
WHERE age>20 &/.hx(#d
#<( = }?
WHERE子句可包括各种条件运算符: eK /?%t
Fyyg`J
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< HmK*b Z
%=j3jj[
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… C}IbxKl
n3MWs);5
NOT BETWEEN…AND… \bCX=E-
=rPrPb
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) Kt>X[o3m,
~#\i!I;RY}
NOT IN (项1,项2……) 6pE :A@
h x6;YV
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE !S%6Uzsj
S~$'WA
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL ea=83 Zj
Wi n8LOC
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR cD1o"bq
&$`hQgi
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 ihT~xt
URcR
2、列表运算符例:country IN ('Germany','China') Uh.Zi3X6}6
6`\]derSon
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 y%]8'q$
H]<]^Zmjy
varchar、text、ntext、datetime和smalldatetime等类型查询。 (UNtRz'=;
B6Ej{q^k,
可使用以下通配字符:
(kTXP_
64Gi8|P
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 PU9`<3z5
<I;*[;AK
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 0JRD
T)7TyE|"2g
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 5H,G-
M
ixwK,
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 r^$~>!kZ|
dEM?~?
例如: f7}"lG]q
z/ &