一、简单查询 @7 Ry{,A
gPd
K%"B@
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 wI@87&
@R&d<^I&M
表或视图、以及搜索条件等。 %]+R>+
"3RFyi
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 6ll!7U(9(
VWft/2p~
SELECT nickname,email 5/"$_7"{a
f~VlCdf+
FROM testtable }n^Rcz6HeO
TIGtX]`
WHERE name='张三' *(9Tl]w
GLsa]}m,9
(一)选择列表 3E*|^*
NY7yk3
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 ?i _ACKpw
sF{~7IB
量和全局变量)等构成。 A3eCI
yd;e;Bb7*
1、选择所有列 k%6CkCw
:a }](Wn
例如,下面语句显示testtable表中所有列的数据: TUfj\d,
v0DDim?cc
SELECT * /p
!A:8
_=mzZe[
FROM testtable '|[!I!WB`
1_+ h"LE
2、选择部分列并指定它们的显示次序 ~HmH#"VP
h%/BZC^L]|
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 Sgi`&;PF
G4(R/<J,BQ
例如: ?Bf>G]zx
Yc[umn^K
SELECT nickname,email 3RaduN]
AR[m+E
FROM testtable xO|r<R7d7
D, ")n75
3、更改列标题 9,?~dx
O,r;-t4vYU
在选择列表中,可重新指定列标题。定义格式为: p!pf2}6Fd
nXT`7
列标题=列名 yXU.PSG*
gkr9+
列名 列标题 p#$/{;yy
4Fg2/O_3
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 \]>YLyG
~e}JqJ(97
标题: 6q^$}eOt
A|ZT;\
SELECT 昵称=nickname,电子邮件=email JX&U?Z
3L&:
FROM testtable 3m>YR-n$
7${<u 0((!
4、删除重复行 7DAP_C
w5>[hQR\
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 ||:>&
RBQ8+^
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 +(*HDa|
iwF_'I$#N
5、限制返回的行数 A4"TJZBg}
Sp\TaUzg
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 cQEUHhRg!
FI^Wh7J
表示一百分数,指定返回的行数等于总行数的百分之几。 FOF@@C~aH
Lap?L/NS
例如: %Y&48''"
Bt<)1_
SELECT TOP 2 * S)U*1t7[
UyRy>:n
FROM testtable lsax.uG5x
CzBYH
SELECT TOP 20 PERCENT * 7eCjp
O h@z<1eYZ
FROM testtable 'C5id7O&
h7#\]2U$[5
(二)FROM子句 <q7o"NI6FZ
m}l);P^
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, <H^jbK
GlJ[rD
它们之间用逗号分隔。 {4S UGo>
~uhW~bT
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 k{2Gq1S{
33~MP;
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 >` s"C
s*PKr6X+
使用下面语句格式加以限定: <1*kXTN(
mOJdx-q?r
SELECT username,citytable.cityid p4P=T@:
}#m9Q[
FROM usertable,citytable 5|rBb[
n.@HT"
WHERE usertable.cityid=citytable.cityid h~#iGs
#&.Znk:@.f
在FROM子句中可用以下两种格式为表或视图指定别名: toA}0MI(:
4
{M
表名 as 别名 5{HF'1XgZ*
H q6%$!q
表名 别名 ]$g07 7o
@ZISv'F
例如上面语句可用表的别名格式表示为: dqB,i9--
Gsh9D
SELECT username,b.cityid obvE m[x!Z
f7*Qa!!2p]
FROM usertable a,citytable b MnD}i&k[
<{W{
Y\_A>
WHERE a.cityid=b.cityid $z_yx
`5
7L
#)yY
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 no+m.B
|Z>-<]p9g
例如: N}5
d}O\:\}y
SELECT a.au_fname+a.au_lname 2WS*c7Ct
Z Qlk 5
FROM authors a,titleauthor ta 6)1PDlB
`dm*vd
(SELECT title_id,title OkC.e')Vx
vhF9|('G
FROM titles +JI,6)Ry
fd4gB6>
WHERE ytd_sales>10000 B :%Vq2`
43k'96[2d
) AS t SA'g`
Bv7FZK3
WHERE a.au_id=ta.au_id bo#xqSGQ
ir6aV|ea!
AND ta.title_id=t.title_id vN(~}gOd\
G/JGb2I/7|
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 uBts?02
7> f2P!:
(三)使用WHERE子句设置查询条件 Milp"L?B%
~B[e*|d
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: B=]j=\o
<Z.`X7]Uk
SELECT * F`4W5~`
7@"X?uo%o
FROM usertable Zd-qBOB2L
w!"A$+~
WHERE age>20 lZAGoR;0Ra
i1x4$}
WHERE子句可包括各种条件运算符: 3u
j|jwL
6],?Y+_;)L
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< f2c<-}wR
.QP`Qn6 (P
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… fBh"
X QLP|v;"
NOT BETWEEN…AND… U LS>v
B!mHO*g
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) J3y_JoS
uNI&U7_"
NOT IN (项1,项2……) $Z;8@O3
V(Pw|u"
e
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE +7%?p"gEY\
o<A-ETx<
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL _1?u AQ3,
N?m)u,6-l
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR 9X*Z\-
kL zjK]4 *
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 xp1/@Pw?
te[uAJ1 N
2、列表运算符例:country IN ('Germany','China') O`CZwXD
S$SCW<LuN
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 c9c]1XJ
#jBmWaP.
varchar、text、ntext、datetime和smalldatetime等类型查询。 ?8$`GyjS
2@bOy~$A
可使用以下通配字符: J t.<Z&
\j!/l
f)
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 0m1V@3]7>
(_#E17U)_
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 \
C:Gx4K
I+Fy)=DO9
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 V_
(Ly8"1;
]+`K\G ^X
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 PI L)(%X
vFHeGq70j
例如: `=;}I@]zj)
H,c1&hb/w
限制以Publishing结尾,使用LIKE '%Publishing' *-*V>ntvT$
nZ=[6?
限制以A开头:LIKE '[A]%' RCfeIHL
>A{e,&