SQL是英文Structured Query Language的缩写,意思为结构化查询语言。SQL语言的主要功能就是同各种数据库建立联系,进行沟通。按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select, Insert, Update, Delete, Create, 以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作。下面,我们就来详细介绍一下SQL语言的基本知识。 ; l* [, h! P6 s
. i. I7 U& f0 k% \7 V( M' z 5 A" q, O9 I% b# M t- _* B+ E : [7 U- {5 [# o- z, Y. S
< align=center> % L" d/ J0 Y& s: V# T ` <FONT size=3><B>数据库表格</B></FONT> . F% t4 k* P7 d$ F5 G1 }- h. ~ 6 R. |( g Z, g& Q
9 Y3 U7 h# [- n" o 一个典型的关系型数据库通常由一个或多个被称作表格的对象组成。数据库中的所有数据或信息都被保存在这些数据库表格中。数据库中的每一个表格都具有自己唯一的表格名称,都是由行和列组成,其中每一列包括了该列名称,数据类型,以及列的其它属性等信息,而行则具体包含某一列的记录或数据。以下,是一个名为天气的数据库表格的实例。 0 l9 N N+ Z# }$ Q: ]. J + B# G0 H( x( [% |
<DIV align=center>, C6 L/ c- D" I5 ~. R2 U X
<CENTER># C% @$ _. a6 S
<TABLE cellSpacing=1 cellPadding=7 width=384 borderColorLight=#ffd048 border=1> ' n9 ^+ A# }$ E: r8 [ <TBODY> 2 \# a" J+ Q) H <TR>3 [5 e$ j D1 k' P7 g0 t) O* T8 u: x E
<TD vAlign=top width="29%">城市 </TD> 1 _, t B9 G7 ?+ T% X g <TD vAlign=top width="36%">最高气温 </TD> 3 d& l( P8 H% J8 G6 Z <TD vAlign=top width="36%">最低气温 </TD></TR>0 g6 v4 i5 V- Y9 Y
<TR> # ^1 H, T) P/ K! ?; |7 a <TD vAlign=top width="29%">北京 </TD> - A- x4 l1 n+ O9 t <TD vAlign=top width="36%">10 </TD>2 q6 u6 L; Z" t: m
<TD vAlign=top width="36%">5 </TD></TR>$ C0 R$ ]. B0 J1 `- Z! {
<TR>) O' W [* w1 ?, ~
<TD vAlign=top width="29%">上海 </TD>+ V4 ^( E4 `+ `5 l$ X# {
<TD vAlign=top width="36%">15 </TD> * V# D: H' u5 v p, | <TD vAlign=top width="36%">8 </TD></TR>. v9 \/ N# o* y# C+ X& X3 ], B
<TR> $ { _" d3 |( N' _ <TD vAlign=top width="29%">天津 </TD># Z) |, L9 D( i
<TD vAlign=top width="36%"><FONT size=3>8</FONT></TD>2 X- X7 h `6 x0 q; p
<TD vAlign=top width="36%"><FONT size=3>2</FONT> </TD></TR> 8 L1 e; U; h* P+ I* J/ e* y <TR>8 y$ W5 G5 U3 {- R, i. }, }2 }8 @
<TD vAlign=top width="29%"><FONT lang=ZH-CN face=宋体>重庆</FONT></TD>7 Y' Z: g* D7 U3 g' L
<TD vAlign=top width="36%"><FONT size=3>20</FONT></TD> 7 c h9 |4 J! @2 f( J( `; p C <TD vAlign=top width="36%"><FONT size=3>13</FONT> </TD></TR></TBODY></TABLE></CENTER></DIV> # U2 |# `" [- U t0 k < align=justify>: z# g% `# M6 H
该表格中“城市”, “最高气温”和“最低气温”就是三个不同的列,而表格中的每一行则包含了具体的表格数据。7 ?( m c% c, B3 I
3 p0 @& f/ F5 P- b4 K8 W4 @# o5 U
< align=center> # w4 u7 q: u( Y* c6 H4 B( Z- L9 X <FONT size=3><B>数据查询</B></FONT>4 h' J o- J1 b; ]
) p! Q! R# Q% q [" u9 A [7 B
$ t& h) U* l* i
在众多的SQL命令中,select语句应该算是使用最频繁的。Select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据。Select语句的语法格式如下: ' F t6 n# ~3 q/ b& z) J; V # I; ?/ w8 c) s5 |! R& q( x ) z- z6 V, c' k P; R. p l% I1 H select column1 [, column2,etc] from tablename; a- {. U2 n, a: o3 [' _5 w
8 E! E0 g+ N+ P6 Y' z2 H: e
J) j* t3 \5 o( T [where condition]; ) D+ Z. R3 _7 S) R5 ~) H ) _) z3 \0 e+ D* q% @, y/ d) v! s 2 G% r; s7 P% N) j+ f. F
([] 表示可选项); I' M! \3 ~* F, ?* R6 T1 O( O% c
3 t i& ]4 d2 E. o/ f) p3 w: t , T, |! O U9 |$ O8 n select语句中位于select关键词之后的列名用来决定那些列将作为查询结果返回。用户可以按照自己的需要选择任意列,还可以使用通配符“*”来设定返回表格中的所有列。( J. v" |! j6 S6 j$ G
$ @ R ]6 N9 o2 B8 ]/ l; p
[& X% I+ B- d& S( Z select语句中位于from关键词之后的表格名称用来决定将要进行查询操作的目标表格。, X& P) K) F0 Q4 Z4 H! U
& d, D* S0 E% _7 p F
+ n$ r! p( c( n; E Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示。 " D! I: e* g/ O( L, {7 F. F+ j l ( }1 R1 S3 t, u$ g) A R # `6 {( V, d8 v% R 在where条件从句中可以使用以下一些运算符来设定查询标准:* w) O7 R' k: ?: p' S8 r4 X& v0 p$ ]
+ p* z3 J2 |$ s; c3 f% e( O- V1 w * p8 L; T" W4 F' j: k' C. G0 B. M
= 等于- X, l' Y+ [/ G) @) ]& H
P) \) H- U( [# g4 r" Y - x- e) @: \& L# ]3 Q( g > 大于) R+ l8 c5 C) ?9 t* K I: O* H/ C4 A
, l2 L/ \9 v( r& \/ q" l # s* S2 k9 b8 _. `+ O B" N < 小于 7 `( O1 Z, D" E% _7 u& O % e4 l4 n; A/ [4 C: \
8 @4 F8 c6 S/ ~$ i) y
>= 大于等于! E( d. x: R7 t
: T9 ]5 K0 d' @
' W" u, I1 A. }, c" u+ N( F6 ^ <= 小于等于# O" q( b" H# ~7 N- s
" v5 g& @9 H. d K6 b* j 8 Q5 x7 h6 B9 h; n0 X& `3 h0 D# R
<> 不等于 u3 X1 v0 H; o3 x+ V( z/ x$ j
. T: {6 G: y1 G- U
( J, R$ y) O$ u. A( w
除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要。LIKE运算符的功能非常强大,通过使用LIKE运算符可以设定只选择与用户规定格式相同的记录。此外,我们还可以使用通配符“%”用来代替任何字符串。举例如下:- a( \+ P6 H" J
3 S+ q' ~" K! ~- H5 \ 9 a1 Q* H3 ^& _* o. k
select firstname, lastname, city ! h! R3 E: \+ w& y) g1 `" T/ C ; T" C$ u% A; c0 O- S
* q$ y3 I) f; L9 L8 z$ ?; C: ^! d1 r
from employee- {; S, c1 J4 O8 L
3 Z' L* K2 M# @! _# d }; H! E& y- {+ K( Z6 u
where firstname LIKE ‘E%’;3 n" _: E+ ~4 y4 M) A; V! T
( v2 i( F1 O6 c( b3 }4 f * q( ^% P% k9 A/ l( u; o (注意,字符串必须被包含在单括号内) ; r) F; \3 J$ ]: C( z * |2 p7 S) r. A8 z, ]( N
# |- `: z9 b" i! f 上述SQL语句将会查询所有名称以E开头的姓名。或者,通过如下语句: b7 Z9 w4 j4 X7 Y% {# T1 b" M * c6 Z( O9 O; ^% I
$ l% G+ ?3 E j( r" x/ ^! `3 G
select * from employee 1 V/ p& e" l6 Y/ W3 q5 |# R * d1 v1 }$ r* |5 B$ h- u % Z/ n) o2 R5 |5 {- _- @7 k8 I where firstname = ‘May’;6 @" Y) L7 g$ ?. {7 _
) v+ ]6 `% X& Q- `+ f1 n b4 m5 j7 x0 r' X5 {. y |, A
查询所有名称为May的行。