社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 4457阅读
  • 0回复

[原创]SQL查询语句使用

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

一、简单查询 'eBD/w5U  
4 ;_g9]  
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 !D1#3?L  
LodP,\T  
表或视图、以及搜索条件等。 e%pohHI  
7l-MV n_8  
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 =U~53Tg  
hwUb(pZ  
SELECT nickname,email  g4q{ ]  
|in>`:qk  
FROM testtable e}5x6t  
~*3Si(4l/  
WHERE name='张三' 7R[7M%H  
Z0H_l/g  
(一)选择列表 VXZYRr3F  
bx2<WdLyT  
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 bn|HvLQ"1  
%cDGs^lgA  
量和全局变量)等构成。 6@lZVM)E  
v(0ujfSR0  
1、选择所有列 au19Q*r9  
G[ns^  
例如,下面语句显示testtable表中所有列的数据: c/.s`hz  
.= ~2"P  
SELECT * =/j!S|P  
/Bgqf,N |  
FROM testtable 0J[B3JO@M  
oMYFfnoAa  
2、选择部分列并指定它们的显示次序 &Oz  
0?t;3 z$n  
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 PUD8  
~pH!.|k-&  
例如: sa<\nH$_X  
;~r-P$kCY  
SELECT nickname,email ]O:u9If  
}s?w-u+(c6  
FROM testtable ?/T=G k  
|1H9,:*%  
3、更改列标题 n|WSnm,W  
o3Yb2Nw  
在选择列表中,可重新指定列标题。定义格式为: )%p46(]  
H(Wiy@cJn  
列标题=列名 \s)$AF  
X! 6dg.n5  
列名 列标题 /m>SEo\{C  
8 [,R4@  
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 vv)O+xt  
}vx 46  
标题: q;QasAQS`p  
I+W,%)vb  
SELECT 昵称=nickname,电子邮件=email ze9n}oN  
Ki:t!vAO  
FROM testtable S['%>  
]qZj@0#7n  
4、删除重复行 V/DMkO#a  
};}N1[D   
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 dm_Pz\ *  
qp*~  |  
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 ,hJx3g5#n  
BE&8E\w  
5、限制返回的行数 *1-0s*T  
HD{u#~8{  
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 dg*xo9Xi`  
EJz!#f~  
表示一百分数,指定返回的行数等于总行数的百分之几。 . WJ  
jR:\D_:  
例如: R$IsP,Uw  
e\aW~zs 2  
SELECT TOP 2 * ;B2&#kot7  
0H%zkJ>Q  
FROM testtable ro?.w  
S{ F\_'%  
SELECT TOP 20 PERCENT * pHoxw|'Y  
FeZWS>N  
FROM testtable )#4(4 @R h  
jC:D>  
(二)FROM子句 N0$ uB"  
z*b|N45O  
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图, wZCboQ,  
Fsq)co  
它们之间用逗号分隔。 9X1vL  
c*axw%Us  
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 h7.jWJTo  
8?'=Aeo  
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 ;){ZM,Ox  
>(YH@Z&;  
使用下面语句格式加以限定: t]vv&vk>  
iM9k!u FE  
SELECT username,citytable.cityid xrY >Or  
c>c4IQ&d  
FROM usertable,citytable >e.vUUQ{  
yXtQfR  
WHERE usertable.cityid=citytable.cityid E*tT^x)  
;InMgo,  
在FROM子句中可用以下两种格式为表或视图指定别名: &'DR`e O)  
D8B\F5..c#  
表名 as 别名 ./DlHS;  
>D##94PZ  
表名 别名 h<'tQGC  
Kx[+$Qt  
例如上面语句可用表的别名格式表示为: w .M  
i*4v!(E  
SELECT username,b.cityid e50xcf1u  
\%]lsml  
FROM usertable a,citytable b *\iXU//^)  
tNqSCjQ~_c  
WHERE a.cityid=b.cityid T8*;?j*@  
o9M r7  
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 i(e=  
wUg=j nY   
例如: F!?f|z,/  
|z@AvS[  
SELECT a.au_fname+a.au_lname Y)(w&E>1  
|yj0Rv  
FROM authors a,titleauthor ta wwR}h I(  
]<%NX $9\  
(SELECT title_id,title |,TBP@  
/-^{$$eu  
FROM titles XMI5j7C L  
F$|d#ny  
WHERE ytd_sales>10000 KdTWi;mV2-  
l]R7A_|  
) AS t n#?y;Y\  
#IqRu:csp  
WHERE a.au_id=ta.au_id V!@6Nv  
FSkX95  
AND ta.title_id=t.title_id SuV3$-);z  
x=\W TC  
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 hSps9*y  
7;6'=0(  
(三)使用WHERE子句设置查询条件 cV`NQt<W  
v$;URF%^  
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: a 7b1c!  
"ZNy*.G|[  
SELECT * ?< Ma4yl</  
|Z o36@s  
FROM usertable &`]T# ">  
'c/8|9jX  
WHERE age>20 M3d%$q)<rW  
x FvK jO)  
WHERE子句可包括各种条件运算符: j@UE#I|h  
Hy'EbQ  
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< r M}o)  
JnQ@uZb`  
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… ,a2=OV  
@,G\` ;Ma  
NOT BETWEEN…AND… LH@Kn?R6  
x A*6Z)Y  
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) AS4oz:B  
CqX*.j{  
NOT IN (项1,项2……) m("KLp8  
9*!*n ~  
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE Cnu])R  
 ,HNk<W  
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL iK5[P  
}-Nc}%5  
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR i\4YT r,  
S%G&{5  
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 ;D(6Gy9~  
.F _u/"**  
2、列表运算符例:country IN ('Germany','China') 9A`^ (  
Z;dR :|%)  
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 0d 0ga^O  
%bG\  
varchar、text、ntext、datetime和smalldatetime等类型查询。 ']^]z".H  
@aB7dtM  
可使用以下通配字符: TOvsW<cM  
nF,zWr[x  
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 ),%@X  
\4fuC6d2  
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 %_39Wa  
['6Sq@c)  
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 NUuIhB+  
R=iwp%c(  
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 ?2gXF0+~Y2  
r. rzU  
例如: &< FKcrZ,  
R_:lp\S&  
限制以Publishing结尾,使用LIKE '%Publishing' ;jKLB^4nX  
(K ]wk9a  
限制以A开头:LIKE '[A]%' [KW)z#`*  
9zLeyw\  
限制以A开头外:LIKE '[^A]%' ^>fr+3a"P  
3@0!]z^W  
4、空值判断符例WHERE age IS NULL *^Z -4  
T&<ee|t@{  
5、逻辑运算符:优先级为NOT、AND、OR y"_rDj`  
O^3XhTW^\~  
(四)查询结果排序 w`/~y   
szOa yAS  
使用ORDER BY子句对查询返回的结果按一列或多列排序。ORDER BY子句的语法格式为: g`6I,6G  
*~UK5Brf1  
ORDER BY {column_name [ASC|DESC]} [,…n] z4]z3U<}3]  
3]&le[.  
其中ASC表示升序,为默认值,DESC为降序。ORDER BY不能按ntext、text和image数据类型进行排 W=n Hi\jLV  
@cG+ D  
序。 *oh,Va  
>v1.Gm  
例如: Pn ?gB}l  
!xU\s'I+#  
SELECT *  \5HVX/  
8SupoS  
FROM usertable T.WN9= N  
\M Av's4b@  
ORDER BY age desc,userid ASC BY$L[U;@T  
I5Rd~-="G  
另外,可以根据表达式进行排序。 6>b#nFVJ  
)L"J?wTe  
  qE6D"+1y7  
mF>{cVTF  
二、联合查询 {JfL7%  
nbDjoZZ4  
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联 IY@N  
OskQ[ e0  
合查询。UNION的语法格式为: M'NOM>8  
&o`LT|*m  
select_statement 1CUI6@Cz)  
@G|z _  
UNION [ALL] selectstatement 8K\S]SZ  
E6?0/"  
[UNION [ALL] selectstatement][…n] a{.-qp  
}C JK9*Z  
其中selectstatement为待联合的SELECT查询语句。 0/~{,  
oSO~72  
ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一 g(o^'f  
WjvgDNk  
行。 6x16?x  
P qa;fiJ)  
联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语 u*T#? W?  
8;3I:z&muQ  
句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。 h,MaF<~  
&sJ6k/l  
在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选 >ATccv  
 Q 6r  
择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类 WvcPOt8Bp>  
:;&3"-  
型,系统将低精度的数据类型转换为高精度的数据类型。 7lzmAih  
@Fb 2c0?Y  
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如: zRm@ |IT  
-_>E8PhM  
查询1 UNION (查询2 UNION 查询3) tYhNr  
?{OU%usQwE  
  lQ2vQz-J  
Et&PzDvU  
  Ol8Yf.e_  
pO N@  
三、连接查询 W;F=7[h  
J2!)%mF$  
通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型 c <X( S  
[3v&j_  
数据库管理系统的一个标志。 y*-D  
)jw!, "_4  
在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在 ?oU5H  
\?$kpV  
一个表中。当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带 k !g%vx  
ca'c5*Fs  
来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行 o"qG'\x  
aBKJd  
查询。 e8)8QmB{o  
u X(#+  
连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于 kM7 6?M  
o4YF,c+>q  
将连接操作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。 ]QF*\2b-I2  
V B=jK Mi  
SQL-92标准所定义的FROM子句的连接语法格式为: `bNLmTS  
ca:Vdrw`  
FROM join_table join_type join_table z2;<i|Ez0  
u/` t+-A  
[ON (join_condition)] io7Zv*&T0  
\Bl`;uXb  
其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一 YcM 0A~<  
m3`J9f,c/  
个表操作的连接又称做自连接。 y6>fK@K~  
~@D{&7@  
join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。内连接(INNER JOIN)使用比 iMF-TR  
w#>CYP`0k6  
较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 7C~g?1  
$T*g@]   
的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。 8 HD I]  
is{H >#+"  
外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN) /,+&O#SX  
3Io7!:+  
和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹 xp]_>WGq  
9y;zk$O8  
配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 jjg[v""3|  
r@G34Q C+  
数据行。 4z^VwKH\j  
_TVKvRh  
交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的 if+97^Oy  
Az6tu <  
数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 ohPDknHp  
bO }9/Ay  
连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑 rG'W#!^*  
]KQBek#DD  
运算符等构成。 ]fU0;jzX  
,veI'WHMB  
无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接 Bv^5L>JZ/  
.Q DeS|l  
连接。例如: P5Pb2|\*  
R7Z!  
SELECT p1.pub_id,p2.pub_id,p1.pr_info piAFxS<6  
v.>95|8  
FROM pub_info AS p1 INNER JOIN pub_info AS p2 [9~6, ;6  
ov|pXi<e  
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) WCg&*  
Q&&oP:4~X*  
(一)内连接 {BD G;e  
x,QXOh\a  
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分 Jy-V\.N>s  
8LGNV&Edg  
三种: OJ<V<=MYZ  
l'Uj"9r,  
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接 {\n?IGP?wd  
uiaZ@  
表中的所有列,包括其中的重复列。 P:m6:F@hO  
N[sJ5oF  
2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些 Rrp-SR?O  
A 7zL\U4  
运算符包括>、>=、<=、<、!>、!<和<>。 nZ# 0L`@"Y  
1m<8M[6u  
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询 ' -rRD\"q  
]=(PtzVa  
结果集合中所包括的列,并删除连接表中的重复列。 .\"8H1I\T  
?PU7xO;_  
例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社: .-cx9&  
D8)6yPwE  
SELECT * Vv*](iM  
Gg5+Ap D  
FROM authors AS a INNER JOIN publishers AS p > |(L3UA9  
'E4}++\  
ON a.city=p.city Eu$hC]w  
q4Y7 HE|ym  
又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state): ; r95i1a'  
Z4D[nPm$  
SELECT a.*,p.pub_id,p.pub_name,p.country X=%e'P*X  
t+A9nvj)  
FROM authors AS a INNER JOIN publishers AS p 4&G #Bi  
*m[[>wE  
ON a.city=p.city o|y1m7X  
H ~lvUHN  
(二)外连接 ZO]P9b  
a}'dIDj  
内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件 d, 0Klew  
$SdpF-'  
的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 ,y[8Vz?:  
lZ?YyRsa6&  
连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 <4.j] BE  
3NN )ql  
如下面使用左外连接将论坛内容和作者信息连接起来: sQLjb8!7  
/q?g py  
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b Gw+pjSJL`  
"; mlQyP  
ON a.username=b.username F??gVa aj  
9rgvwko  
下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市: !iU$-/,1e  
f<3lxu  
SELECT a.*,b.* af}JS2=$  
E[c6*I  
FROM city as a FULL OUTER JOIN user as b Dh)(?"^9A  
REJHh\:.77  
ON a.username=b.username #bGYd}BfD  
WUGFo$ xA  
(三)交叉连接 %8?XOkH)  
F+ <Z%KuCu  
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数 gm7 [m}  
$dF$-y<[0  
据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 Z~ u3{  
fY!9i5@'  
例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等 nt*K@  
`a9iq>   
于6*8=48行。 il$eO 7  
n {..Q,z  
SELECT type,pub_name tiF-lq  
%;b]k  
FROM titles CROSS JOIN publishers ?vmoRX  
C(2kx4n  
ORDER BY type
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

描述
快速回复

您目前还是游客,请 登录注册
欢迎提供真实交流,考虑发帖者的感受
认证码:
验证问题:
10+5=?,请输入中文答案:十五