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

[原创]SQL查询语句使用

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

一、简单查询 |[ k.ii6iO  
(\hx` Yh=>  
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的 7#ibN!  
q#ClnG*  
表或视图、以及搜索条件等。 %D}kD6=  
|w1Bq  
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。 FR4QUk  
}`QUHIF  
SELECT nickname,email JG!mc7  
Cc' 37~6~P  
FROM testtable +wvWwie  
R_ ,UMt  
WHERE name='张三' Ug t.&IA  
K'Tm_"[u  
(一)选择列表 ," Wr"  
Z/;(f L  
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变 >WQMqQ^t@  
Mxsa-?R;v  
量和全局变量)等构成。 k,E{C{^M  
EZy)A$|  
1、选择所有列 QP^Cx=  
l7259Ro~  
例如,下面语句显示testtable表中所有列的数据: ]&xk30  
otl0J Ht*+  
SELECT * _jI,)sr4ic  
XQs1eP'{  
FROM testtable z Rl3KjET  
:W:K:lk  
2、选择部分列并指定它们的显示次序 lhz{1P]s  
K{cD+=]{  
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。 DV+xg3\(>1  
t?ZI".>  
例如: ^ft>@=K(|  
YEs&  
SELECT nickname,email R{3N&C  
,o{9$H5{  
FROM testtable *:YiimOY"  
DiScFx |rE  
3、更改列标题 KRLQ #,9  
3yY}04[9<  
在选择列表中,可重新指定列标题。定义格式为: q J=~Y|(  
nntuLuW  
列标题=列名 2*< nu><b  
w%VU/6~  
列名 列标题 HU }7zK2  
m )zUU  
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列 kg~mgMR+w  
@ ZwvBH  
标题: Zq|I,l0+E  
wd^':  
SELECT 昵称=nickname,电子邮件=email eV"h0_ox  
YTpSHpf@  
FROM testtable )uIe&B  
?)?Ng}  
4、删除重复行 ;| 5F[  
zh`<WN&H  
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认 wj<6kG  
/y#f3r+*2  
为ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。 =Z3F1Cq?  
f ue(UMF~  
5、限制返回的行数 Sh~dwxp*"  
}6}l7x  
使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n是 r CHl?J  
)!Z*.?  
表示一百分数,指定返回的行数等于总行数的百分之几。 -M~:lK]n   
OU(8V^.  
例如: GR.^glG?6  
u+e{Mim  
SELECT TOP 2 * Z{Qu<vy_  
Y3cMC)  
FROM testtable qu6D 5t  
D|L9Vs`  
SELECT TOP 20 PERCENT * C12Fl  
%2/EaaR  
FROM testtable eKLZt%=  
`$<.pOm  
(二)FROM子句 |'8Nh  
Nk 8B_{  
FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图,  O67W&nz  
mPK:R^RjG&  
它们之间用逗号分隔。 n;Q7X>-f8`  
g i-$Z FzB  
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列 4*#18<u5  
H8zK$!  
所属的表或视图。例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 \*y-g@-{W$  
V-2(?auZd  
使用下面语句格式加以限定: v0+BkfU+p  
4qh?,^Dq  
SELECT username,citytable.cityid \0I_<  
cJ n=  
FROM usertable,citytable VUGmi]qd  
]^'Kd*x  
WHERE usertable.cityid=citytable.cityid xJvmhN/c  
L>NL:68yN  
在FROM子句中可用以下两种格式为表或视图指定别名: 9r<J"%*Q  
"]x'PI 4J  
表名 as 别名 Y%aCMP9j~9  
PfD.:amN7  
表名 别名 ~i{(<.he  
TG?brgW  
例如上面语句可用表的别名格式表示为: e/&{v8Hmb  
]BZA:dd.G  
SELECT username,b.cityid q[ZTHd.-  
=tn)}Y.<e  
FROM usertable a,citytable b 0c]/bs{}  
N7QK> "a  
WHERE a.cityid=b.cityid ,vawzq[oSy  
\ gGW8Q;  
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。 Z'W =\rl  
KVaiugQ   
例如: [z\$?VJspQ  
2'\H\|  
SELECT a.au_fname+a.au_lname dNH08q8P  
g \:[ 55;8  
FROM authors a,titleauthor ta 1~`fVg  
cN6X#D  
(SELECT title_id,title EhvX)s  
rmm0/+jY  
FROM titles NiK4d{E&  
E\EsWb  
WHERE ytd_sales>10000 u8g~  
v`x.)S1  
) AS t Tc:)- z[o  
FFpT~.  
WHERE a.au_id=ta.au_id ({)+3]x  
fc3{sZE2M  
AND ta.title_id=t.title_id [;yOBF  
W:nef<WH  
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。 On.{!:"I/  
rJT a  
(三)使用WHERE子句设置查询条件 F6|]4H.3Q  
 RVmh6m  
WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据: EU;9 *W<  
o5GcpbZ3k  
SELECT * (@VMH !3  
LEf^cM=>  
FROM usertable  vF+7V*<  
n\D&!y[]F  
WHERE age>20 P=Jo+4O  
"| g>'wM*  
WHERE子句可包括各种条件运算符: ncdKj}  
vWv"  
比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!< T2W eE@o  
$6 9&O  
范围运算符(表达式值是否在指定的范围):BETWEEN…AND… ,Vm < rK  
hH 3RP{'=  
NOT BETWEEN…AND… {9pZ)tB  
c_pr  
列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……) UHkMn  
N!=v4f  
NOT IN (项1,项2……) Lv7(st%`  
3M7/?TMw{6  
模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE Tv=mgH=b  
uyWunpT  
空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL 2- h{N  
qgHWUwr+n  
逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR AKfDXy  
>\#*P'y`d  
1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30 Eyqa?$R  
C2I_%nU Z1  
2、列表运算符例:country IN ('Germany','China') p%Vt#?q  
&`r-.&Y  
3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char、 -3 *]G^y2  
m dg8,n  
varchar、text、ntext、datetime和smalldatetime等类型查询。 k%#EEMh  
rJ4S%6w  
可使用以下通配字符: FVbb2Y?R  
f~R(D0@  
百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。 /-'}q=M  
%)1?TU  
下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。 i9|Sa6vuI  
fU}ub2_in  
方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。 |aS.a&vwR  
@*XV`_!h  
[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。 P3=G1=47U  
MJO-q $)c  
例如: 3jU&zw9  
-d/ =5yxL  
限制以Publishing结尾,使用LIKE '%Publishing' d&Zpkbh"  
yx[/|nZDC4  
限制以A开头:LIKE '[A]%' '<)n8{3Q5w  
Q&tG4f<  
限制以A开头外:LIKE '[^A]%' L`TLgH&?R  
U '_Q>k  
4、空值判断符例WHERE age IS NULL ET*SB  
Of#u  
5、逻辑运算符:优先级为NOT、AND、OR Mfuv0P~  
4F:\-O  
(四)查询结果排序 f'RX6$}\1X  
R) h#Vc(  
使用ORDER BY子句对查询返回的结果按一列或多列排序。ORDER BY子句的语法格式为: 'JE`(xD  
V=l0(03j~  
ORDER BY {column_name [ASC|DESC]} [,…n] Ic<2QknmP  
Wvh#:Z  
其中ASC表示升序,为默认值,DESC为降序。ORDER BY不能按ntext、text和image数据类型进行排 ebhXak[w  
Q3~H{)[Kq  
序。 Nh|uO?&C6  
=y*IfG9b  
例如: t{9GVLZ  
;H*T^0  
SELECT * eo?bL$A[s  
;igIZ$&  
FROM usertable |wMN}bq|T  
sl l\g  
ORDER BY age desc,userid ASC Z5n1@a __  
%[TR^Th6  
另外,可以根据表达式进行排序。 qe#tj/aZ  
2]*OQb#O6e  
  ? OM!+O  
!f [_+CD  
二、联合查询 <'oQ \eB  
PC8Q"O  
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联 (ZZ8L-s  
]_gU#,8  
合查询。UNION的语法格式为: q3!bky\  
@S;'@VC  
select_statement /,yd+wcW#  
 mq.`X:e  
UNION [ALL] selectstatement ZMlm)?m  
dZ@63a>>@  
[UNION [ALL] selectstatement][…n] J/$&NWF  
f8dB-FlMm  
其中selectstatement为待联合的SELECT查询语句。 &p@O _0nF  
6nvz8f3*r]  
ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一 Yj49t_$b  
wn%A4-%{  
行。 p6V0`5@t  
$6 f3F?y7  
联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语 1GcE) e!>  
TD0 B%  
句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。 W ac&b  
rb.N~  
在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选 6bC3O4Rw  
x 9fip-  
择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类  }my`K  
-Q*gW2KmV  
型,系统将低精度的数据类型转换为高精度的数据类型。 5t]H?b8  
a1lh-2x X  
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如: q0vQ a  
,f>k%_U}  
查询1 UNION (查询2 UNION 查询3) Y:[u1~a  
u*`GiZAO  
  ^09,"<@k  
&h/X ku&0  
  :"c*s4  
U5de@Y  
三、连接查询 DvvK^+-~  
#\m<Sz5Gp#  
通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型 onzxx4bax  
(\x]YMLH  
数据库管理系统的一个标志。 wIt}dc  
Fx.=#bVX7  
在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在 #_p\Ie*rd  
sO@Tf\d  
一个表中。当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带 zrb}_  
B]tQ(s~  
来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行 O\ r0bUPE  
{P_.~0pc*  
查询。 6i/(5 nQ  
26h21Z16q  
连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于 b ]KBgZ  
b \2 ds,  
将连接操作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。 ~4'$yWG  
I!K6o.|1  
SQL-92标准所定义的FROM子句的连接语法格式为: 3!]rmZ-W  
xA*<0O\V  
FROM join_table join_type join_table > ~O.@|  
1yhDrpm  
[ON (join_condition)] Dlvz )  
s$j,9uRr  
其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一 InI$:kJ  
ww1[rCh\+  
个表操作的连接又称做自连接。 ]/L0,^RI  
[7y]n;Fy  
join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。内连接(INNER JOIN)使用比 8":Q)9;%  
SmO~,2=  
较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 |sE'XT4ag  
WpvhTX  
的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。 3JR+O <3D  
S f# R0SA  
外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN) 9->if/r,o  
t?FBG4  
和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹 R:qW;n%AF  
M o|2}nf  
配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 (E1~H0^  
$ I?"lky  
数据行。 >A"(KSNL  
pQB."[n  
交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的 %xLh Z\  
V0mn4sfs  
数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 Ny/MJ#Lq  
Mi_$">1-W  
连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑 )^hbsMhO  
?S=mybp  
运算符等构成。 %WS+(0*1  
JBZ@'8eqi]  
无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接 [:*)XeRK  
_+MJ%'>S  
连接。例如: ns4,@C$  
I> $&-i  
SELECT p1.pub_id,p2.pub_id,p1.pr_info OY({.uVdX  
FS1z`wYP  
FROM pub_info AS p1 INNER JOIN pub_info AS p2 E]r?{t`]  
w0unS`\4  
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) |R:'\+E  
YS_; OFsd  
(一)内连接 dPRra{  
Wd ELV3  
内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分 *LY8D<:zs  
U6s[`H3I{  
三种: f|(M.U-  
6Kz,{F@  
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接 I]q% 2ie  
K*dCc}:`  
表中的所有列,包括其中的重复列。 \|[;Z"4l  
G3v5KmT  
2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些  %;!.n{X  
Y_P!B^z3  
运算符包括>、>=、<=、<、!>、!<和<>。 |y!A&d=xYn  
,/unhfs1q  
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询 DtnEi4h,  
],].zlN  
结果集合中所包括的列,并删除连接表中的重复列。 -UT}/:a  
3G4-^hY<  
例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社: &%Tj/Qx  
,R|BG  
SELECT * 93hxSRw  
0{SL&<&  
FROM authors AS a INNER JOIN publishers AS p ddR>7d}N  
C7AUsYM  
ON a.city=p.city 5F"jk d+  
9N3eN  
又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state): d'sZxU  
kcx Ad   
SELECT a.*,p.pub_id,p.pub_name,p.country x,Vr=FB  
kU`r)=1"  
FROM authors AS a INNER JOIN publishers AS p 2J;g{95z  
/Ci<xmP  
ON a.city=p.city P0b7S'a4!  
$ME)#(  
(二)外连接 !|>"o7  
0m ? )ROaJ  
内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件 ~Cjn7  
a[TMDU;(/4  
的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 T[j,UkgGo  
u#SWj,X  
连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 3+bt~J0  
vfo~27T{(  
如下面使用左外连接将论坛内容和作者信息连接起来: ig &Y  
"zy7C*)>r  
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b #LOwGJ$yVz  
8\gjST*  
ON a.username=b.username v.5+7,4  
BsJC0I(  
下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市: 4X|zmr:A  
xN%K^Tree  
SELECT a.*,b.* :\U{_@?`%  
g=o4Q< #^y  
FROM city as a FULL OUTER JOIN user as b po7qmLq  
v*yuE5{  
ON a.username=b.username #3d(M  
7VI*N)OZ8  
(三)交叉连接 @\I#^X5lv  
pb=h/8R  
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数 f y8Uk;  
*uvQ\.  
据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 TuqH*{NNy9  
FC"8#*x  
例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等 _wL BA^d^  
7t_^8I%[  
于6*8=48行。 `@|$,2[C  
^sg,\zD 'X  
SELECT type,pub_name sn>~O4"  
>yh2Lri  
FROM titles CROSS JOIN publishers &iVs0R  
\D&KC,i5f  
ORDER BY type
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

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

描述
快速回复

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