一、简单查询 &.yX41R
pwSkw J]
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 {#@[ttw$U
WHjJR
表或视图、以及搜索条件等。 1S+T:n
rK;<-RE<[:
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 RxPD44jVA
Rm,>6bQx
SELECT nickname,email g hkV^ [
c9nv=?/}f
FROM testtable )FA:wsy~E
9P#kV@%(0c
WHERE name='张三' wr:-n
r-WX("Vvh
(一)选择列表 8In~qf
m,6u+Z,
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 (VC Jn<@@
X$t!g`
量和全局变量)等构成。 j+lcj&V#
r>KmrU4Q
1、选择所有列
f/.f08
!)J$f_88D
例如,下面语句显示testtable表中所有列的数据: )"tM[~e`
1B 0[dK2N
SELECT * n#?y;Y\
#IqRu:csp
FROM testtable p?
VDBAx
wJgH15oB
2、选择部分列并指定它们的显示次序 +>Y]1IlI
#4nBov3d
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 e !w{ap8u
tk 5p@l
例如: .k
up[d(
?vik2RW
SELECT nickname,email 5YI6$ZdQ
L"T :#>
FROM testtable eAQ-r\h'2
Z)3oiLmD
3、更改列标题
<ZO+e*4
FKf2Q&2I
在选择列表中,可重新指定列标题。定义格式为: x>4p6H{]0'
3RlNEc%)
列标题=列名 ZRr.kN+F
]haQ#e}WH
列名 列标题 mZ?QtyljT
vQoZk,
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 931GJA~g
&u<%%b|
标题: d?/g5[
pma=*
SELECT 昵称=nickname,电子邮件=email R$eEW"]
7coVl$_Zl
FROM testtable (v0Q.Q@<
]-+l.gVFW
4、删除重复行 HYJEz2RF
/;y`6WG%2
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 NOAz"m+o
(
YZ2&
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 S,Qa\\~z
qsQTJlq)
5、限制返回的行数 GbkDs-
VhnIr#L+
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 {?cF2K#
(II#9n)
表示一百分数,指定返回的行数等于总行数的百分之几。 Z;dR:|%)
(enOj0
例如: %bG\
']^]z".H
SELECT TOP 2 * ?ZhBS3L
TOvsW<cM
FROM testtable nF,zWr[x
bXM&VW?OP
SELECT TOP 20 PERCENT * \4fuC6d2
:"i2`y;u
FROM testtable i8*(J-M
^7:UC\_
(二)FROM子句 B'PS-Jr
B\ZCJaMb
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, ^%U`|GBZp
B" ]a8}u
它们之间用逗号分隔。 P+e {,~o
)2jH&}K
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 wr>6Go%
'OU3-K
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 x.I?)x!C'
@RdNAP_6
使用下面语句格式加以限定: DoN]v
j97K\]tQ
SELECT username,citytable.cityid yZmeke)_
4~vn%O6n
FROM usertable,citytable %Go/\g
],zp~yVU&
WHERE usertable.cityid=citytable.cityid Q}
-YD.bx3
:o:/RR p[
在FROM子句中可用以下两种格式为表或视图指定别名: O/&Qzt
#! (2@N8
表名 as 别名 I;{Ua*
W6u(+P]("
表名 别名 ?. L]QU
TyR@3H
例如上面语句可用表的别名格式表示为: xHkx rXqeI
4dI`
SELECT username,b.cityid b>}
)G7b}
i\K88B&24
FROM usertable a,citytable b cA90FqUH
Yqt~h
WHERE a.cityid=b.cityid n(Um/
|B2>}Y/
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 T7?z0DKi
MTbCL53!-
例如: y8v0>V0)
a\p`J 9Z@
SELECT a.au_fname+a.au_lname vhU#<59a1
H.tfn>N|
FROM authors a,titleauthor ta 0^d<@\
|g<l|lqz|
(SELECT title_id,title R0q|{5S
OskQ[
e0
FROM titles H<*n5r(c
^*,?x
WHERE ytd_sales>10000 7e)j|a-!<
EgOiJH
) AS t ~UwqQD1p
}fhGofN$e
WHERE a.au_id=ta.au_id BMn`t@ !x
, LqfwA|
AND ta.title_id=t.title_id pA\"Xe&
@~i :8
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 +a+DiD>./
v#5hK<9
(三)使用WHERE子句设置查询条件 8'Q&FW3"
,jy9\n*<t9
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: Q_k'7Z\g$
Z v 7}C
SELECT * ]-OF3+l4
zpcO7AY~
FROM usertable TH~"y
j:2*hF!E
WHERE age>20 l%
{<+N
d @b ]/
WHERE子句可包括各种条件运算符: e,*@+E\4
uJ3*AO
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< %)o;2&aD
LP?*RrM
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… z
E\~Oa;
VF~kjH2>
NOT BETWEEN…AND… N1l^%Yf J
}~v0o#
I
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) NU3s^ 8\(
f!B\X*|
NOT IN (项1,项2……) A%EGu4
;a(7%
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE AaM~B`B
1f$1~5Z
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL J
c:j7}OOV
jZ<f-Ff0
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR bZgFea_>i
.ITTY QHv)
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 f Qf5%
3AcDW6x|
2、列表运算符例:country IN ('Germany','China') Et;Ubj"+
j__l'?s
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 lQVK~8t3
75c\.=G9q<
varchar、text、ntext、datetime和smalldatetime等类型查询。 TTSq }sb}
Ge*N%=MX8
可使用以下通配字符: 4B-+DH>{6
Fw%S%*B8g
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 e#ne 5
1@q"rPE^
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 fs,>X!l+
zy8D&7Ytf
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 EV
R>R
|#22pq?RP
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 bKr73S9
'.XR,\g>
例如: xHlO~:Lc
+ ;B K|([#
限制以Publishing结尾,使用LIKE '%Publishing' Nbt.y 'd
%eJE@$
限制以A开头:LIKE '[A]%' .R&jRtb/E
"]yfx@)_
限制以A开头外:LIKE '[^A]%' U)_x(B3d/
9y;zk$O8
4、空值判断符例WHERE age IS NULL jjg[v""3|
"X-"uIc
5、逻辑运算符:优先级为NOT、AND、OR 2nI^fVR%\
uh3<%9#\k
(四)查询结果排序 H `_{n<
X7)B)r}AG
使用ORDER BY子句对查询返回的结果按一列或多列排序。ORDER BY子句的语法格式为: ['aiNhlbt
@.h;k4TD
ORDER BY {column_name [ASC|DESC]} [,…n] [:l=>yJ{(
KK/siG~O
其中ASC表示升序,为默认值,DESC为降序。ORDER BY不能按ntext、text和image数据类型进行排 2Jt*s$
F2',3
序。 %5<Xa
b5l;bXp]
例如: <1kK@m -E
I=7 YAm[W
SELECT * 35~1$uRA
28lor&Cc
FROM usertable #!w7E,UBi
UQJ
ORDER BY age desc,userid ASC 3moDu
o#V{mm,{Pm
另外,可以根据表达式进行排序。 ,BlNj^5f
knRs{1}Pw{
^x}k1F3
:a)` iJnb
二、联合查询 W9jxw4)
rf
=Wq_
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联 !4T7@V`G
N?c!uO|h|
合查询。UNION的语法格式为: +LaR_n[
(CY#B%*
select_statement g 4lk
5:SS2>~g
UNION [ALL] selectstatement }%S#d&wh$_
w!52DBOe+
[UNION [ALL] selectstatement][…n] <!PbD
p ^ )iC&*0
其中selectstatement为待联合的SELECT查询语句。 DP!~WkU~
2h`Tn{&1/
ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一 --F6n/>
{A{sRT=%
行。 N"zm
\mNN ) K@
联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语 _k Utj(re
t:tIzFNv
句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。 \T^ptj(0
Z<[:v2
在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选 f
SMy?8
7~nuFJaTI
择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类 0W]vK$\F*
/(DnMHn\
型,系统将低精度的数据类型转换为高精度的数据类型。 6Vu)
rWip[>^
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如: B[;aNyd<
}k_'a^;C1
查询1 UNION (查询2 UNION 查询3) !5>PZ{J
%G'P!xQhy
?l^NKbw
8]xYE19=
S.*LsrSV
_''9-t;n,
三、连接查询 k6(0:/C
l6pvQ|
通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型 v`r*Yok;`
|L(h+/>aWX
数据库管理系统的一个标志。 4Xe8j55
iB5'mb*
在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在 %ZGG6Xgw
C\}M_MD
一个表中。当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带 f^G-ba
Er<!8;{?
来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行 oVIc^yk5a
R dLk85<n
查询。 TECp!`)j"
|eP5iy wg
连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于 FR6PY
'oF ('uR
将连接操作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。 *)s^+F 0
]+T$D
SQL-92标准所定义的FROM子句的连接语法格式为: aJ
J63aJ
f;obK~b[
FROM join_table join_type join_table 4,?WNPqo
;.3
{}.Y
[ON (join_condition)] 3shd0q<
QNGp+xUHJ9
其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一 kp^q}iS
7
/XfPF
个表操作的连接又称做自连接。 \qtdbi|Y
!>EK
%OO
join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。内连接(INNER JOIN)使用比 jm,c Vo
Jj~|2Zt
较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 .a 9f)^
N@V:nCl
的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。 LU+}iA)
Q
6dqFnz
外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN) pg{cZ1/
<l<6W-I
和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹 yBfX4aH:`
^#4Ah[:XA
配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 Oe lf^&m
<yw56{w,
数据行。 XCyr r2^
%#E$wz
交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的 gB]jLe
@]dv
数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 L#\5)mO.v
!HKW_m^3J
连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑 UvuAN:'
bRK\Tua
6
运算符等构成。 0e(4+:0
+6:jm54
无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接 i'[! 'HY
:jFZz%
连接。例如: )oy+-1dE
b fI= =
SELECT p1.pub_id,p2.pub_id,p1.pr_info >{>X.I~
?Zc(Zy6
FROM pub_info AS p1 INNER JOIN pub_info AS p2 L+8O
4K{
s\0,@A
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) C@u}tH
)
Op:$7hv
(一)内连接 !1Nh`FN
r(JP&
@
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分 '~zi~Q7M
2IXtIE
三种: ywA7hm
vPAL,
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接 hP$5>G(3
5 hW#BB
表中的所有列,包括其中的重复列。 b"w@am>&
e'.CIspN
2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些 C]Q}HI#G
P 2)/!+`a
运算符包括>、>=、<=、<、!>、!<和<>。 3ej[
^#U[v7y
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询 9V>C %I
v1=N?8Hz1
结果集合中所包括的列,并删除连接表中的重复列。 W=Mdh}u_I
bZpx61h|
例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社: 8L5O5F'
gObafIA
SELECT * K|=va>
3!`_Q%
FROM authors AS a INNER JOIN publishers AS p ~U5Tn3'~
8\p"V.o>
ON a.city=p.city !\cVe;<r
MhIHfW]b
又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state): ha7mXGN%
X2'XbG3
SELECT a.*,p.pub_id,p.pub_name,p.country S" (Nf+ux
v7,- Q*
FROM authors AS a INNER JOIN publishers AS p >96+s)T%;
l[[^]__
ON a.city=p.city X6xs@tgQ
zF(abQ0
(二)外连接 |?TX^)
t+D= @"BZP
内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件 (S2E'L L{
YKzfI9Y
的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 P_)=sj!>-
1'|gxYT
连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 NdrR+t^#
yQf(/Uxk*x
如下面使用左外连接将论坛内容和作者信息连接起来: Adgfo)X5
,P=.x%
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b jwSPLq%
G!lF5;Ad`
ON a.username=b.username pl/ek0QX
]}n|5
下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市: ZO>)GR2S
[}l#cG6 k
SELECT a.*,b.* RDEK=^J
eKf5orN
FROM city as a FULL OUTER JOIN user as b 4vV\vXT *
KY?ujeF
ON a.username=b.username fNBI!=
{7%(m|(
(三)交叉连接 wCu!dxT|,
rPt
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数 PsOq-
}zqo<o
据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 4BeHj~~
p{+F{e
例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等 U2CC#,b!(
8fktk?|
于6*8=48行。 ]dgi]R|`
+ WT?p]
SELECT type,pub_name VCwC$ts
Yv0y8Vz@
FROM titles CROSS JOIN publishers ?Ezy0>j
f?>
?jf
ORDER BY type