一、简单查询 AA0zt N
h\$juIQa
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 9]TvLh3
"t)|N
dZm
表或视图、以及搜索条件等。 ;X2 (G
J*CfG;Y:
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 5mYI5~
p
wa4(tM2
SELECT nickname,email Qz?r4kR
4 '-GcH
FROM testtable VNLggeX'U
n`)wD~mk
WHERE name='张三' h ^6Yjy
2VNfnk
(一)选择列表 #2*2xt
t#[u
X?
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 -, #LTW<.
z;EnAy {9
量和全局变量)等构成。 l<mEGKB#
k@= LR
1、选择所有列 P(BV J_n
Z<0+<tt
例如,下面语句显示testtable表中所有列的数据: M.R]hI
N%&D(_
SELECT * b/Z0{38
#ZRplA~C7]
FROM testtable -"e$ VB
13T0"}
2、选择部分列并指定它们的显示次序 A/"p PO
m}3POl/*j
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 +~A<&7[}
#%i-{t+_>
例如: b,#E.%SLw
a,N?GxK~
SELECT nickname,email nu#_,x<LS
p@7[w@B\c
FROM testtable UPkD^D,
.%4{zaB
3、更改列标题 R'q:Fc
rpT{0>5
在选择列表中,可重新指定列标题。定义格式为: UMJ>6Ko8
<KDl2>O
列标题=列名 W<D(M.61A
7+I2"Hy
列名 列标题 {E~MqrX
pQY.MZSA
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 wB;'+d&
q:1_D>
标题: z!I(B^)BkT
5Y8/ZW~D0
SELECT 昵称=nickname,电子邮件=email :K6(`J3Y"^
o=
%Fh
FROM testtable 9GZKT{*
[af<FQ {
4、删除重复行 emV@kN.
9)qjW &`
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 '?~k`zK
?DC3BA\)
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 N|ut^X+|\
%8V/QimHU
5、限制返回的行数 Pl
}dA
7^~pOFdH
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 _;BN;].
4JHFn [%
表示一百分数,指定返回的行数等于总行数的百分之几。 oIM]
f9FsZD
例如: hsQrHs'k
?eb2T`\0Q
SELECT TOP 2 * [-sE:O`yt
[N/[7Q/y
FROM testtable u= K?K
66%#$WH#
SELECT TOP 20 PERCENT * kgz2/,
pAV}hB
FROM testtable T@]vjXd![
(r^IW{IndX
(二)FROM子句 /y,~?
g'`J'6Pn
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, )]%GNdU
k:w\4Oqd
它们之间用逗号分隔。 q*ZjOqj
1!/
U#d"
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 AX%9k
:!1B6Mc
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 yV xR||e
]*^mT&$7
使用下面语句格式加以限定: qfY.X&]PU
2I'\o7Y
SELECT username,citytable.cityid Wv"[,5
Z13
'Z7oPq6
FROM usertable,citytable 0n_Cuh\
VPf*>ph=
WHERE usertable.cityid=citytable.cityid (o\:rLZu
'7W?VipU
在FROM子句中可用以下两种格式为表或视图指定别名: m4nJ9<-
xnu|?;.}!
表名 as 别名 +MQf2|--
A;h0BQm/j
表名 别名 Fa9]!bW
UJ)\E
^Hp
例如上面语句可用表的别名格式表示为: t9PS5O ;
2D
MH@U2
SELECT username,b.cityid ~2~KcgPsq
S[NV-)r=
FROM usertable a,citytable b }d)>pH
Z\{WBUR;4t
WHERE a.cityid=b.cityid ^n<p#0)+a
];1z%.
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 e@L'H)w,
h2KXW}y"4
例如: 6kjBd3
/
GJ"##<
SELECT a.au_fname+a.au_lname j*$GP'Df3
{P(Z{9 u%
FROM authors a,titleauthor ta oa`,|dA"
/+J?Ep(_
(SELECT title_id,title F#iLMO&Q
6[c
LbT0
FROM titles $+ZO{
(
tGD$cBE
WHERE ytd_sales>10000 ;'pEzz?k"
~?6V-m{>#
) AS t tZ=BK:39\
0pu])[P]_[
WHERE a.au_id=ta.au_id qrNW\ME
(^9q7)n
AND ta.title_id=t.title_id (>>pla^
.dp~%!"Sn,
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 A
A<9XC
;oULtQ
(三)使用WHERE子句设置查询条件 ix]3t^
:M ix*NCf
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: r[M]2h
'8k\a{t_z
SELECT * (1(3:)@S6
mw`%xID*
FROM usertable \J-O b
r#]gAG4t\
WHERE age>20 pp#Kb 2*
w]) bQ7)
WHERE子句可包括各种条件运算符: gA!-F}x$
F)_Rs5V:(
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< Ajq;\-:
t22BO@gt74
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… oRy?Dx+H
& HphE2 h
NOT BETWEEN…AND… dlK#V)
Z5-"a?{Y
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) $}OU~d1q
0c7&J?"wE
NOT IN (项1,项2……) f;pR8
0wZLkU_(
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE ?GD{}f33
5HL JkOV5
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL h:#
.rG Rdb
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR ERGDo=j
v[r:1T@
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30
`Xmf4
))G%C6-
2、列表运算符例:country IN ('Germany','China')
4m#i4
<5[wP)K@
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 =[t( [DG
,`/!0Wmt
varchar、text、ntext、datetime和smalldatetime等类型查询。 ui G7
Fdu0?H2TL
可使用以下通配字符: yKOf]m>#
5&2=;?EO
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 `W?aq]4x5
2;[75(l6|}
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 >|@ /GpD
):LJ {.0R
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 IDE@{Dy
#B`"B
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 Cl<`uW3
q'+XTal
例如: vxr3|2`
:XBeGNI*#
限制以Publishing结尾,使用LIKE '%Publishing' l%fnGe` _
8,dCx}X
限制以A开头:LIKE '[A]%' 0NpxqeIDY
)/bt/,M&}
限制以A开头外:LIKE '[^A]%' _h@7>+vl~
&sJpn*W
4、空值判断符例WHERE age IS NULL pVt-7AgW
9S&6u1
5、逻辑运算符:优先级为NOT、AND、OR Mk|h ><Q"
'$1-A%e$1
(四)查询结果排序 ;N ]ElwP
'D\(p,(Mt
使用ORDER BY子句对查询返回的结果按一列或多列排序。ORDER BY子句的语法格式为: -Q 6W`*8
cy^6g?ew
ORDER BY {column_name [ASC|DESC]} [,…n] qdZn9i
4^70r9hV9
其中ASC表示升序,为默认值,DESC为降序。ORDER BY不能按ntext、text和image数据类型进行排 fgn*3 pg
.yi.GRk
序。 xE;fM\7pu
o0s+ roiD
例如: LL9Mty,
i0p"q p
SELECT * MV9{>xX
a/L?R
Uu
FROM usertable ?@_3B]Fs
39"8Nq|e
ORDER BY age desc,userid ASC 6n%^
U2H/-
"M_X9n_
另外,可以根据表达式进行排序。 ~O@V;y
nm %ka4
Rc?wIL)
G*ym[
二、联合查询 RF g$N@g,
nN@8vivP%
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联 `U(A 5
jh\q2E~,`
合查询。UNION的语法格式为: X?4tOsd
% OiSuw
select_statement QE<63|
RG:ct{i
UNION [ALL] selectstatement Eto0>YyZ
4vBZb^W;9
[UNION [ALL] selectstatement][…n] uZmfvMr3
w{2V7*+l
其中selectstatement为待联合的SELECT查询语句。 e
*;"$7o9
",&}vfD4M
ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一 _a15R/S
m>zUwGYEu
行。 us`hR!_
ZW+{<XTof4
联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语 oPzt1Y
fcJ#\-+E
句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。 `'Z ;+h]
;EL!TzL:8
在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选 rU.ew~
zFB$^)v"<
择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类 z<^HohT
tBrd+}e2*
型,系统将低精度的数据类型转换为高精度的数据类型。
Q9%N>h9
VD36ce9
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如: _e ~EQ[,
^!pagt^
查询1 UNION (查询2 UNION 查询3) 'f;+*~*L
wF@qBDxg
d+2I+O03
iKp4@6an
Pb]s+1
;K$E;ZhPN
三、连接查询 <-}6X
3@ay9!Xq
通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型 %@H;6
4^AE;= Q
数据库管理系统的一个标志。 !i)?j@D
%0:
(''
在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在 4~G9._
Z"e|DP`
一个表中。当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带 tV#x{DN
I!# 42~\
来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行 Gt6$@ji4u
V-7!)&q
查询。 oB_{xu$6|
Q6.},o
连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于 \8_&@uLm
L2Gm0 v
将连接操作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。 *<Qn)Az
=H!u4
SQL-92标准所定义的FROM子句的连接语法格式为: LAMTf"a
}p8a'3@Z
FROM join_table join_type join_table (U$ F) 7
{CQA@p:Y}
[ON (join_condition)] lQ!6n
!u\ X,.h
其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一 n~K_|
YM1@B`yWE
个表操作的连接又称做自连接。 s{IycTbz
)5&w
join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。内连接(INNER JOIN)使用比 s|EP/=9i
EkOBI[`
较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 ~2rZL
?LvZEiJ
的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。
93o}vy->
[[[p@d/Y
外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN) n!3_%K0!r&
5^f>L2
和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹 /A<L
#G9S[J=xe
配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 Q3z-v&^E9
7z F29gC
数据行。 K-p1v!IC
bS*
"C,b~s
交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的 K[T?--H
zbi[r
数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 Du[$6
j>?c]h{-
连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑 4V<s"
`+]4C+w
运算符等构成。 rC/m}`b
FeSe^ ^dW
无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接 M@s2T|bQw
L
F Z
连接。例如: g<}K^)x
uWi+F)GS^K
SELECT p1.pub_id,p2.pub_id,p1.pr_info :[\}Hn=
3}LTEsdM
FROM pub_info AS p1 INNER JOIN pub_info AS p2 #Q$9Eq8"[
UKk~)Of
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) |*OS;FD5
MlS<txFPS
(一)内连接 (y#8z6\dx
uF@Q8 7G
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分 8~rD#8`6j
I.q nA
三种: S
G]e^%i
0Ba-VY.H
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接 t[iE >
0P%(4t$pd
表中的所有列,包括其中的重复列。 9<\wa/#
>KM<P[BRd
2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些 In^$+l%O[
N55;oj_K
运算符包括>、>=、<=、<、!>、!<和<>。 Ngh9+b6[
Q@/wn
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询 !cp
,OrO\
-br/
结果集合中所包括的列,并删除连接表中的重复列。 e[w)U{|40
"E8-76n
例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社: DghX(rs_
rDUNA@r
SELECT * e~nmIy
>8>`-
FROM authors AS a INNER JOIN publishers AS p +a"Asvw2
EiIbp4*e
ON a.city=p.city ,C(")?4aJ
%2bZeZ
又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state): J/R=O>
X#gZgz ='
SELECT a.*,p.pub_id,p.pub_name,p.country h_x"/z&
l"b78n
FROM authors AS a INNER JOIN publishers AS p q9icj
Uhb6{'+
ON a.city=p.city Z"% =
s 6vsV
(二)外连接 ZZzf+F)T
V A4_>6
内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件 C37KvLQ
fLct!H3
的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 f=g/_R2$xN
^<[oKi;>
连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 ZDcv-6C)B
(lS&P"Xi
如下面使用左外连接将论坛内容和作者信息连接起来: )k <ON~x
O' A''}M
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b D8BK/E-
URX>(Y}g9^
ON a.username=b.username MDl
rkG*0#k
下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市: SDDs}mV
8WfF: R;
SELECT a.*,b.* 5pE[}@-c9
hY/SR'8
FROM city as a FULL OUTER JOIN user as b 7PHvsd"]p
2syKYHV
ON a.username=b.username Ny
p5=
;:8_H0X'K
(三)交叉连接 'hf-)\Ylf
yi
r#G""7
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数 r3_@ L>;
lNls8@
据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 L?4c8!Q
_"##p
例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等 gWv/3hWWB
!T6oD]x3
于6*8=48行。 a}0\kDe
u <D&RT
SELECT type,pub_name WI](a8bm
qW$IpuK
FROM titles CROSS JOIN publishers Y'%sA~g
AX<TkS@wjb
ORDER BY type