一、简单查询 F<UEipe/N
g8{?;
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 g]g2`ab |
3}H"(5dL}z
表或视图、以及搜索条件等。 Cz\(.MWNZ
USnKj_e
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 RPvOup
U/B1/96lJ
SELECT nickname,email R;X8%'
lxRzyx
FROM testtable o%Lk6QA$
Cl;B%5yl
WHERE name='张三' R0y@#}JH
j${:Y$VmE
(一)选择列表 3:rH1vG.m
1:%m
>4U
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 d0b--v/
FxKb
量和全局变量)等构成。 )>ed6A1
Q~4o{"3.'
1、选择所有列 [FKmZzEy
gFvFd:"uZ
例如,下面语句显示testtable表中所有列的数据: ;<#fZ0(l;
]D7z&h
SELECT * j=)%~@
5FHpJlFK,
FROM testtable _[V.%k
u pf7:gk +
2、选择部分列并指定它们的显示次序 {MKq
Yl{
2I:vie
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 b9(d@2MtK
Y#c11q Z
例如: E~zLhJTUL'
IPcAE!h6zN
SELECT nickname,email k6~k
:&`Yz
FROM testtable c3|;'s
yov:JnWo
3、更改列标题 [^W4%S
\1RQ),5 %]
在选择列表中,可重新指定列标题。定义格式为: cW),Y|8
!+ IxPn
列标题=列名 U<eVLfSij
Y[;Pl$
列名 列标题 )%C482GO-
J=TbZL4y}4
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 B| %=<1?
d
{moU\W
标题: C4Q^WU+$j
#JZf]rtp
SELECT 昵称=nickname,电子邮件=email C^r 3r6
+U^dllL7
FROM testtable ap\2={u^|
g4d5G=y
4、删除重复行 lw? f2_fi
w"-bO ~5h
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 V/|Ln*rm
t9m:E
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 E[LXZh
gi:;{
5、限制返回的行数 Ih`n:aA
uGJeQ
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 \XMl8G
Lq
LciD
表示一百分数,指定返回的行数等于总行数的百分之几。 )TM ![^d
+:It1`A~]
例如: +F 6KGK[
D}!U?]la&
SELECT TOP 2 * {C*mn !u
(7}v}3/
FROM testtable Q-}oe Q
3Du&KZ
SELECT TOP 20 PERCENT * u!nt0hS
I_#)>%H
FROM testtable UNYU2ze'
y~1UU3k5
(二)FROM子句 Ft`#]=IS
pWps-e
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, e7/J:n$
Bi
kCjP[b
它们之间用逗号分隔。 b]Rn Cu"
9A3Q&@,
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 &)fPz-s
4pq >R
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 ?Dm! ;Z+7
H:9(
XW
使用下面语句格式加以限定: DfV_08
%<DRrKt
SELECT username,citytable.cityid Z#>k:v
AGCqJ8`|T
FROM usertable,citytable RPaB4>
m^T$H_*;
WHERE usertable.cityid=citytable.cityid o|alL-
Cj5M
在FROM子句中可用以下两种格式为表或视图指定别名: ~v,LFIT
)OH!<jW
表名 as 别名 i>,5b1x~
?e]4HHgU]
表名 别名 orzdq
p//">l=Ps
例如上面语句可用表的别名格式表示为: Os@ofnC
LC[,K
SELECT username,b.cityid M?$-u
\|j`jsq
FROM usertable a,citytable b a+weBF#Z
PU?kQZU~)
WHERE a.cityid=b.cityid kHz3_B9[
$am7 xd
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 4)'5;|pI
sd8o&6
例如: 51;(vf
do=VPqy
SELECT a.au_fname+a.au_lname ]X?+]9Fr
|.(o4<nx.
FROM authors a,titleauthor ta |nD2k,S<?
{,s:vPoiA
(SELECT title_id,title 'Q(A5zfN]Y
fhfdNmtR)I
FROM titles zq4mT;rqz
Cn28&$:J
WHERE ytd_sales>10000 L<8y5B~W
e|MyA?`
) AS t zy$hDy0
)\VUAD%~e7
WHERE a.au_id=ta.au_id ,~G _3Oz
A|Y\Y }
AND ta.title_id=t.title_id y62;&{?m
ItOVx!"@9
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 5QSd$J
`i{o8l
(三)使用WHERE子句设置查询条件 R>gj"nB
y-sQ"HPN
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: yuI5#
VUS
E/s3@-/
SELECT * &nz1[,
t'9E~_!C
FROM usertable IyP\7WZ
ZklidHL');
WHERE age>20 m"x~Fjvd
%],.?TS2V
WHERE子句可包括各种条件运算符: ' R=o,=
&I!2gf
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< NoYu"57\
zo\XuoZ
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… ?LNwr[C0
oY.JK
NOT BETWEEN…AND… N(1jm F
L</"m[
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) gXw\_ue<
}#E4t3
NOT IN (项1,项2……) u5R^++
j/B zbjq"
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE 5@Py`
Nr(WbD[T
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL 8sbS7*#
m,up37-{
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR %eT/:I
zNXkdw
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 cPS!%?}I
7B&nV92S
2、列表运算符例:country IN ('Germany','China') Ip2JzE
+pe_s&
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 )YnB6@=nyk
|}mBW@ah
varchar、text、ntext、datetime和smalldatetime等类型查询。 =G=.THRUk
i:[B#|%
可使用以下通配字符: d1E~H]X4
9d2$F9]:o
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 7<