一、简单查询 j8/rd
!Ld0c4
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 .)Xyzd
g/H:`J
表或视图、以及搜索条件等。 y9W6e"
-={Z::}S"
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 tMM*m
0I6[`*|SX
SELECT nickname,email S[!sJ-rG
&h)G>Sqc
FROM testtable /H 3u^
|eS5~0<`
WHERE name='张三' p H&Tb4
&t.9^;(
(一)选择列表 AIZs^
`_
Q}ebw
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 ul0]\(sS:
MbY?4i00%h
量和全局变量)等构成。 . ]
=$((
@0}Q"15,I
1、选择所有列 ]|NwC<
ho*44=j
例如,下面语句显示testtable表中所有列的数据: TI
'(
;-SFK+)R"
SELECT * vrVb/hhG
Wjf UbKg0
FROM testtable r![RRa^
j2GO ZKy
2、选择部分列并指定它们的显示次序 J:6wFmU
]fc9m~0N,\
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 #1-y[w/
aD
yHIh8
例如: 5Fh?YS =
a<AT;Tc
SELECT nickname,email o$dnp`E
K/oC+Z;K
FROM testtable |#<PI9)`
}bj
dK
3、更改列标题 ]ZJu
E]zTd$v6
在选择列表中,可重新指定列标题。定义格式为: >uMj}<g#Z?
n_G< /8
列标题=列名 FPM@%U
_-^bAr`z
列名 列标题 S3cjw9V
*}BaO*A
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 MUo}Qi0K
Z";~]]$!Y
标题: K9JW&5Q
w!$|IC
SELECT 昵称=nickname,电子邮件=email K$>C*?R
H.\gLIr
FROM testtable C>%2'S^.b
Rw4"co6
4、删除重复行 kpc3l[.A
HJFt{tq2
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 8Ar5^.k
6{2LV&T=u
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 bs-O3w
.j*muDVQn
5、限制返回的行数 }9n{E-bj *
R"Ol'y{
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 wNsAVUjLe
L2"fO
表示一百分数,指定返回的行数等于总行数的百分之几。 1.7tXjRd+
:',.I
例如: \@yx;}bdI
2-G he3
SELECT TOP 2 * _N`:NOM
:Ny.OA
FROM testtable #=)(t${7'
h.\V;6ly
SELECT TOP 20 PERCENT * G8}w|'0m
5LVhq[}mP
FROM testtable d*7nz=0&$
p( EV-^
(二)FROM子句 )vH6N _
PoyY}Ra
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, "PA:
b21c} rI3
它们之间用逗号分隔。 aA Hx^X^
OnO56,+S^
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 <~9z.v7
oj.f
uJD
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 D
==H{c1F
U1pL
`P1
使用下面语句格式加以限定: o(~QuHOp8>
j^DoILw
SELECT username,citytable.cityid F+.:Ry FS
j{)_&|^{
FROM usertable,citytable #X&`gDW
y,$kU1yH7
WHERE usertable.cityid=citytable.cityid fmH"&>Loc
CXqU<a&
在FROM子句中可用以下两种格式为表或视图指定别名: )6?(K"T
X"V,3gDG
表名 as 别名 I[|5 DQ
rCGyr}(NC
表名 别名 (_^pX
YGy.39@31
例如上面语句可用表的别名格式表示为: 7P}&<;5zD
*b+ef
SELECT username,b.cityid Kk?P89=*
ia.9 5H;
FROM usertable a,citytable b 63b?-.!b
r)$(>/[$
WHERE a.cityid=b.cityid "S6'<~s
}S{#DgZ@X
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 CRy;>UI
<^j,jX
例如: "b&[W$e
G(7!3a+
SELECT a.au_fname+a.au_lname K07b#`NF6
JTu^p]os?
FROM authors a,titleauthor ta
3Qt-%=b&
v=4,kG
(SELECT title_id,title aa!o::;
0pP;[7k\
FROM titles zUg-M
-)%l{@Mr
WHERE ytd_sales>10000 qaK9E@l
BU|=`Kb|))
) AS t C[h"w'A2
(<f`},
QxD
WHERE a.au_id=ta.au_id Y`@:L'j
<u\j4<p
AND ta.title_id=t.title_id jOs&E^">&B
B%95M|
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 x:bJ1%
o"F=3b~:n
(三)使用WHERE子句设置查询条件 1`1U'ibhe
H.sHXuu
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: (ly4[G1y
#T0uPK
;
SELECT * $bQ[H[4l
@d imZsi1
FROM usertable .
IBy'
Ii"h:GY;\
WHERE age>20 )l}Gwd]h
BM+v,hGY
WHERE子句可包括各种条件运算符:
'UGkL;
_hgu:
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< sqkk4w1#C
uveby:dh
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… U_ j\UQC
Hk'D@(hS
NOT BETWEEN…AND… p<#WueR[
5 rpX"(
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) feOX]g#
qx3@]9
NOT IN (项1,项2……) $[5S M>e]
&)?ECj0`
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE -ea":}/
EHByo[
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL HyKvDJ
3_
"F
nH>g-
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR qV^Z@N+,
E/MD]ox
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 w'NL\>
Opc, {,z6
2、列表运算符例:country IN ('Germany','China') `Pa z
j2A
Z.s
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 4+fWIY1
"
9VyY[&
varchar、text、ntext、datetime和smalldatetime等类型查询。 L;d(|7BVv
J[6`$$l0
可使用以下通配字符: Ke0j8|
:77dl/d%
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 K.k%Tg[ ~
9r,)Bw!RP
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 xVOoYr>O
fUy:TCS
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 SJ(<u2J]
K0hmRR=
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 WP/?(%#Y
8KH|:>s=
例如: V/C":!;
E1 )7gio
限制以Publishing结尾,使用LIKE '%Publishing' '!8'Xo@Go3
L1'R6W~%dN
限制以A开头:LIKE '[A]%' M`6rI
6_`9
4+
限制以A开头外:LIKE '[^A]%' QDO.&G2
d\% |!ix
4、空值判断符例WHERE age IS NULL <Co\?h/<
zo!e<>o
5、逻辑运算符:优先级为NOT、AND、OR 0q6$KP}q
a o"\L0;{
(四)查询结果排序 UVND1XV^f
Yyl(<,Yi
使用ORDER BY子句对查询返回的结果按一列或多列排序。ORDER BY子句的语法格式为: x+niY;Z E
y7a84)j3
ORDER BY {column_name [ASC|DESC]} [,…n] HV_5
+
QahM)Gb
其中ASC表示升序,为默认值,DESC为降序。ORDER BY不能按ntext、text和image数据类型进行排 ''Lf6S`4X~
\]bAXa{ p
序。 /_yJ;l/K
~.-o*
例如: @)"= b!q=
vwA d6Tm
SELECT * TGUlJLT
S6~&g|T,
FROM usertable OsQB`
D
X@:[.eI~
ORDER BY age desc,userid ASC E?,O>bCJ5
> 93I|C|
另外,可以根据表达式进行排序。 2y"]rUS`
;8!L*uMI
(yh zjN~
g9N_s,3jC
二、联合查询 oT=XCa5
x6-bAf
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联 ~!bA<q
'3h"Ol{b
合查询。UNION的语法格式为: /XfE6SBz
rd#O ]
select_statement o5k7$0:t/
hq.XO=0" k
UNION [ALL] selectstatement M$@Donx
o*\Fj}l-
[UNION [ALL] selectstatement][…n] QzV
Q}
VV'K$v3'N8
其中selectstatement为待联合的SELECT查询语句。 x=Ef0v
tv,Z>&OM
ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一 ZT;8Wvo
6S`J7[
行。 ~hx__^]d
mpcO-%a
联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语 6
07"Z\
0+H4sz%.
句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。 1?!z<<
gHLvzm
在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选 o \r6iO
^)\z
择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类 $G
$147z
%yr(i 6L
型,系统将低精度的数据类型转换为高精度的数据类型。 3b9SyU2
k;)t}7(
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如: PG@Uygahu
\xtY\q,[
查询1 UNION (查询2 UNION 查询3) G]DSwtB?D
vh29mzum
ONc-jU^
Qv v~nGq$
gGdt&9z
%
/b
]Yya#
三、连接查询 cN]e{|
_s(izc
通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型 k|kn#X3X
A9:dHOmT^U
数据库管理系统的一个标志。 !Z0p94L
iS/faXe5
在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在 c)5d-3"
xzI?'?duC
一个表中。当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带 klUW_d-
_T8o]
来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行 ZSs)AB_Pe/
/8$*{ay
查询。 pb`!_GmB
mrc% 6Ri
连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于 cq?&edjP
0P?\eoB@8
将连接操作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。 ggP#2I\
xoT|fgb
SQL-92标准所定义的FROM子句的连接语法格式为: e7# B?
[H-r0Ah
FROM join_table join_type join_table 1I^uq>r
Vm_<eyI2
[ON (join_condition)] ` D9sEt_/
n"Gow/-;
其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一 q8Z,XfF^S
iUH{rh!
个表操作的连接又称做自连接。 &I= 27!S
j1Ng[
join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。内连接(INNER JOIN)使用比 f\/'Fy0
cVR#\OM
较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 S*0P[R
";>>{lYA.
的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。 <0%X:q<
(hb\1wZ
外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN) >U%:Nfo3
$t1XoL
和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹 Z` ;.62S
6Z:swgi6&
配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 ue/GB+U
$$GmundqB
数据行。 ` 6'dhB
0P%,1M3d
交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的 |o5F%1o
~"IjT'W3
数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 xklXV
[WAnII
连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑 -\2T(3P
r/ G6O
运算符等构成。 qRX:eo
GELxS!
无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接 r6x"D3
Z'@a@Y+
连接。例如: 'IykIf
q|EE
em
SELECT p1.pub_id,p2.pub_id,p1.pr_info /&T"w,D
ophQdJM
FROM pub_info AS p1 INNER JOIN pub_info AS p2 gPA),
NrN
Gv$}>YJ
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) :SUU)jLq
p1mY@[A
(一)内连接 ~A X@o-WU
6q8b>LG|
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分 u#>*"4Q
5Vj t!%?r
三种: fNh0?/3)
YtWO=+rX
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接 \i}:Vb(^
+hW^wqk/.
表中的所有列,包括其中的重复列。 j/h>G,>T=
z4UJo!{S
2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些 'u)zQAaw.
kpQXnDm2
运算符包括>、>=、<=、<、!>、!<和<>。 7^3a296
E7c!KJ2
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询 SFaG`T=
i_KAD U&mP
结果集合中所包括的列,并删除连接表中的重复列。 4uSC>
2rG;j52))a
例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社: InCJ4D
2b` 3"S
SELECT * /Ayo78Pi
>E:V7Fa
FROM authors AS a INNER JOIN publishers AS p AfV
a[{E
Pv>W`/*_,s
ON a.city=p.city $QbaPmHW
zdh&,!] F6
又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state):
AD=qB5:
HuCzXl
SELECT a.*,p.pub_id,p.pub_name,p.country VD).UdUn
DNu^4#r
FROM authors AS a INNER JOIN publishers AS p ([+u U!
j1sZRl)D
ON a.city=p.city ar#Xe;T!
u5LrZt]k
(二)外连接 EU0b>2n4
555*IT3b
内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件 F79!B
7/:C[J4GTN
的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 GmJ4AYEP
$!Pm*s
连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 Z}E.s@w
i`F8kg`_K
如下面使用左外连接将论坛内容和作者信息连接起来: #$ Q2ijT0
-76l*=|
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b }0%~x,
UmC_C[/n?
ON a.username=b.username ,{tK{XpS
`RriVYc<
下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市: |hlc#t?
<691pkX
SELECT a.*,b.* 6n
R54wNm@
FROM city as a FULL OUTER JOIN user as b
Q9!T@
, (Bo .(]
ON a.username=b.username c-dOb.v0
-#e3aXe
(三)交叉连接 |d@%Vb_
#"6O3.P
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数 B_u1FWc
|v[0(
据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 /&`sB|
f=f8)+5
例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等 ^@"EI|fsP
G';yb^DB
于6*8=48行。 X5V8w4NN
X:ck
SELECT type,pub_name $}* bZ~
Hfw*\=p
FROM titles CROSS JOIN publishers ?mRGFS
=gYKAr^p5
ORDER BY type