一、简单查询 %Q080Ltet
3sK^
(
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 9*2Q'z}_
W]oILL"d
表或视图、以及搜索条件等。 /8? u2
q
nZX`y
-AZ
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 #z5$_z?_
,Dy9-o
SELECT nickname,email VvUP;o&/
Gspb\HJ^
FROM testtable tc|PN+v;
+Ym#!"
WHERE name='张三' | Kq<}R
4[
*G
(一)选择列表 %D49A-R
0<)Ep~!
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 YM,UM>
4d8}g25C
量和全局变量)等构成。 w
y&yK*w
FM"[:&>
1、选择所有列 w&>*4=^a
.^wBv
'Y
例如,下面语句显示testtable表中所有列的数据: (,R\6
Hbl&)!I
SELECT * Ww0dU _
)
S-Fuq4i4
FROM testtable
+O4//FC-"
zXW;W$7V4
2、选择部分列并指定它们的显示次序 (7C$'T-ZK
`4,]Mr1b
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 o0_H(j?
z
.+J\
例如: p{x6BVw?>
TMD*-wYr
SELECT nickname,email v)aV(Oa
T>irW(
FROM testtable qu0q
LM
E %?>
%h
3、更改列标题 %3yrX>Js
I9h{fB
在选择列表中,可重新指定列标题。定义格式为: F$S/zh$)0
ddY-F
}z~
列标题=列名 P! P` MX
AZ
SaI
列名 列标题 69 J4p=c,
75iudki
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 v}=pxWhm
@9lGU#
标题: "?6R"Vk?:
iV:\,<8d
SELECT 昵称=nickname,电子邮件=email i "aQm
Yc5<Y-W
FROM testtable }tJMnq/m($
Q6n8 ,2*
4、删除重复行 M"foP@
fVYv 2
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 $#_^uWN-M
N6v*X+4JH
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 `FK qVd
X^C $|:
5、限制返回的行数 N@"e^i
r#d]"3tH
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 0Qg%48u
=H"%{VeC5
表示一百分数,指定返回的行数等于总行数的百分之几。 xEB4oQ5
9Dyw4'W.N
例如: USXPa[
nTsPX Tat
SELECT TOP 2 * {X W>3 "
@"^(} 6
FROM testtable 3ep
L'My$
0qBXL;sE
SELECT TOP 20 PERCENT * JV!}"[
Ds\f?\Em
FROM testtable eh*F/Gu
^1ks`1
(二)FROM子句 *}LQZFrnX
~'):1}KN]
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, x_EU.924uY
os(}X(
它们之间用逗号分隔。 dTVM
!=
JM*rPzp
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 l_x>.' a
v=H!Y";
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 Pv@;)s(-
!" : arK
使用下面语句格式加以限定: SHCVjI6
FRTvo
SELECT username,citytable.cityid q5w)i
? oGmGKq
FROM usertable,citytable y] ~X{v
Pq(
)2B
WHERE usertable.cityid=citytable.cityid X .S8vlb4z
PvdR)ZEm
在FROM子句中可用以下两种格式为表或视图指定别名: LZu_-I
g? \pH:|79
表名 as 别名 O11.wLNH
yM34G S=,J
表名 别名 u"a$/
4U:+iumy2
例如上面语句可用表的别名格式表示为: *-9b!>5eD
YCQ+9
SELECT username,b.cityid /t?(IcP5
#kGxX@0
FROM usertable a,citytable b hO:X\:G
|&%l @X6
WHERE a.cityid=b.cityid zphStiwIQ
';7|H|,F
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 8%#uZG\}
b;Im +9&
例如: 5*>3(U
s/'gl
SELECT a.au_fname+a.au_lname Ljxn}):[
'C*NyHc
FROM authors a,titleauthor ta )O%lh
8fI
2jx+q
(SELECT title_id,title 9~mi[l~
wGQ{
FROM titles i]LK,'
;3sT>UB
WHERE ytd_sales>10000 "WYcw\@U
FZmYv%J
) AS t iVu+ct-iv
k*c:%vC!
WHERE a.au_id=ta.au_id 2i(|? XJ^
Pjb9FCA'
AND ta.title_id=t.title_id |_2ANWHz
<CmsnX
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 p r0V) C6
6l
vx
(三)使用WHERE子句设置查询条件 v
V^ GIWK
= xX^
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: D#t5*bwK
sqZHk+<%
SELECT * BtHvfoT
M*S5&xpX
FROM usertable V!U[N.&$
8:xQPd?3
WHERE age>20 ycAQPz}=I
n
~3c<{coZ
WHERE子句可包括各种条件运算符: (&nl}_`7?,
;W*$<~_
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< +tN-X'u##
.CpF0
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… zuPH3Q={
e #OU {2X
NOT BETWEEN…AND… w9PY^U.Y3e
7z,M`14
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) u ?Xku8 1l
L
wu;y@[
NOT IN (项1,项2……) )nk>*oE
N+V-V-PVk
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE 68!fcK
&4[iC/}
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL d#tUG~jc
vPsX!m[#
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR 3U`.:w`
X>6a@$Mx P
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 ZF/KV\Ag)
yEny2q}
2、列表运算符例:country IN ('Germany','China') #?=cg]v_
,{50zx2
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 T7Ac4LA
4dK@UN\
varchar、text、ntext、datetime和smalldatetime等类型查询。 ~z}au"k
wm8x1+P
可使用以下通配字符: Z9D4;1
W Q&<QVK
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 80EY7#r@w
V"ZbKV+[
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 p o`$^TB^+
&B4U)
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 f.$o|R=v
;Z_C3/b
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 rh&on