数学建模社区-数学中国

标题: SQL语言快速入门 [打印本页]

作者: ╃無名草╃    时间: 2004-10-3 13:59
标题: SQL语言快速入门
SQL是英文Structured Query Language的缩写,意思为结构化查询语言。SQL语言的主要功能就是同各种数据库建立联系,进行沟通。按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select, Insert, Update, Delete, Create, 以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作。下面,我们就来详细介绍一下SQL语言的基本知识。
" b9 y/ y4 i  b% }3 s8 p
! a7 F& g$ k+ H% h4 B4 K9 i8 J9 h
5 A! b4 D3 U; N* H) P 5 w6 m7 n) ~, g7 _7 @
&lt align=center>( N2 h" J) S. ]
<FONT size=3><B>数据库表格</B></FONT>+ _* {6 r! i5 \8 A) s
3 X" g$ J: u* ]3 f" l1 v
: G* h" _, S$ z. b& C
  一个典型的关系型数据库通常由一个或多个被称作表格的对象组成。数据库中的所有数据或信息都被保存在这些数据库表格中。数据库中的每一个表格都具有自己唯一的表格名称,都是由行和列组成,其中每一列包括了该列名称,数据类型,以及列的其它属性等信息,而行则具体包含某一列的记录或数据。以下,是一个名为天气的数据库表格的实例。' R6 q$ }& p" T6 \$ S" x
3 ~" L5 b/ D7 G" x  J
<DIV align=center>
( A0 J1 K- l; G% P5 c <CENTER>* h' K" }+ e$ a
<TABLE cellSpacing=1 cellPadding=7 width=384 borderColorLight=#ffd048 border=1>8 v5 G3 k. O3 e5 }# H6 f4 T
<TBODY>' t! R- B0 q# l2 c6 _' t9 J
<TR>
5 g1 M: L. t, N  \2 U2 H4 f  a4 | <TD vAlign=top width="29%">城市 </TD>
' ^. m) x) {5 h7 V! U <TD vAlign=top width="36%">最高气温 </TD>
( M" n' u$ d: E0 U3 E9 p0 ? <TD vAlign=top width="36%">最低气温 </TD></TR>
! ~* ?4 ]& Y4 T% f% y <TR>0 j$ [+ W* Z* u* A
<TD vAlign=top width="29%">北京 </TD>
, D- e; b/ `! f# Y  X" v) K$ x <TD vAlign=top width="36%">10 </TD>
8 n; f3 q1 G) H1 Y; l: _) R <TD vAlign=top width="36%">5 </TD></TR>
+ j0 B7 \. O3 _- r <TR>
  H! k; m8 [: X3 j) @# w1 ?/ f, e <TD vAlign=top width="29%">上海 </TD>$ t3 b6 v6 S. q- q3 J
<TD vAlign=top width="36%">15 </TD>
/ E& r) t: d; B* B <TD vAlign=top width="36%">8 </TD></TR>( s- n# K' v! L+ j
<TR>
+ O5 Z: I! @, o% R <TD vAlign=top width="29%">天津 </TD>$ d- b0 J) |5 E) G( W4 r# k; \! ~
<TD vAlign=top width="36%"><FONT size=3>8</FONT></TD>
0 [! _4 J0 p: n6 @& H0 X2 w/ z" d <TD vAlign=top width="36%"><FONT size=3>2</FONT> </TD></TR>
, o2 u1 b! X# D4 S <TR>
, N0 y, u. `; o: {% F: W <TD vAlign=top width="29%"><FONT lang=ZH-CN face=宋体>重庆</FONT></TD>
; J) {7 \% A3 l <TD vAlign=top width="36%"><FONT size=3>20</FONT></TD>6 L0 M$ Y2 Q' `
<TD vAlign=top width="36%"><FONT size=3>13</FONT> </TD></TR></TBODY></TABLE></CENTER></DIV>* ^- \8 J1 v3 A1 w' L
&lt align=justify>
- r6 t3 g2 @0 J3 c 该表格中“城市”, “最高气温”和“最低气温”就是三个不同的列,而表格中的每一行则包含了具体的表格数据。& Q& i/ t2 a$ o( Y8 Q! l$ l

( {3 [& s4 |% R% C: p8 l& R &lt align=center>" ^5 u- f& W1 U
<FONT size=3><B>数据查询</B></FONT>. q6 E; M4 }6 Z* z8 H+ ?, S
9 E9 z* @+ R1 \' w) z9 P5 X
1 C  S  Y0 J) g1 T9 ]" |
  在众多的SQL命令中,select语句应该算是使用最频繁的。Select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据。Select语句的语法格式如下:
" v% @7 z& c* g) z7 K0 G* t9 A  f 8 D% i8 J( R' A
2 q* B8 S! l0 Z& y( j2 Y( S( r
select column1 [, column2,etc] from tablename8 O- _* t5 \: C7 F% r# ~

9 g: W2 D, r: G# u3 d  n  e   ?' b  z( P! e
[where condition];
6 A9 |8 Z. J/ R
3 N5 w& q' I$ x" m7 Z 7 ^2 O% b9 _' s$ Z) S) |1 l3 X
([] 表示可选项)# s8 V/ l! I3 @

2 H7 K/ O0 J5 X. i2 G$ |
" z+ x7 ^0 m) A" d0 e, X7 ^9 A; U3 v   select语句中位于select关键词之后的列名用来决定那些列将作为查询结果返回。用户可以按照自己的需要选择任意列,还可以使用通配符“*”来设定返回表格中的所有列。
  G2 s0 X$ G+ a% P5 y7 z( G3 h1 d0 b   h# m( ?* U2 R$ g1 ^) S' }

4 F. B- f) A5 a3 ~ select语句中位于from关键词之后的表格名称用来决定将要进行查询操作的目标表格。
* k: o! l8 T" M' ]# \5 F' o2 Y , e$ |2 z" d% o
+ g7 _  P9 u% T7 J
Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示。1 O& Q9 }+ s  L: r1 d1 o3 Y

/ \" o+ I) |& ^  H, R+ X8 W
; |! t# f; m5 S/ { 在where条件从句中可以使用以下一些运算符来设定查询标准:
8 z7 g" I- N3 S- X% q ( P; u" \# a0 ?$ E8 }( Q

: |- k( e* S  i' \* W! d6 Z = 等于$ J, A( U) D7 ~  b" b

1 q8 _3 v8 r, k, C: \ / l. v" J. Y3 L
> 大于4 p, u5 O) j7 O: T% m& B

" z+ j. V$ ^7 ]/ w# B6 Q- s3 N 5 m6 L( f( S5 a" r1 V% e) h
< 小于6 e, j: C! }3 l
5 f' N+ X7 v/ z/ N7 u& ]+ J

: a/ Z# [, i" c" _( O3 C >= 大于等于; j) Y: p. v. q: W4 J+ r7 k
- J; t& x6 K6 w  b; v- |3 m
1 i  f4 R( K( y4 ]
<= 小于等于
3 X( A) a1 _! T: Q% P' x
/ l6 b7 N) w9 {" i ' m! X0 b% _( e' \, D7 V) c. z
<> 不等于
* u" W% v+ @- E' W0 I7 n 8 N1 [7 O$ L, w3 e$ I7 _
* a* [1 r# F/ ^* Z
  除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要。LIKE运算符的功能非常强大,通过使用LIKE运算符可以设定只选择与用户规定格式相同的记录。此外,我们还可以使用通配符“%”用来代替任何字符串。举例如下:) m; l: g+ w2 J& c4 Y# e
1 K" c# ?- @$ N) l/ D
, {% J( D* [5 }" d
select firstname, lastname, city9 v0 b3 w4 G0 l% g
9 D! o3 R3 r; S2 O  E
- A9 c; ^  i8 [4 B
from employee3 `* n; w' u+ p! U: n

2 g2 e* R% s+ x' m2 T- @, z , f3 I% \. J* z6 m; n/ H
where firstname LIKE ‘E%’;
0 [$ M" {1 _: p
" t8 t1 R( g2 k9 R
* Z5 w6 [7 Y: {, r (注意,字符串必须被包含在单括号内)1 n- Y* Y" q: ?. ]- d+ e" {' @
1 L9 Q# ^$ L' R2 \0 p5 n/ v
/ E1 R0 l3 ]/ a3 R; I
上述SQL语句将会查询所有名称以E开头的姓名。或者,通过如下语句:
2 h' I( ^5 \2 Q2 t# ^% X$ |8 R
* Y) q; s  j4 h9 G & w0 o: b! B; l0 n
select * from employee
- k; R: ]3 U8 r
1 o3 @& }" ~* V* R$ V0 |* @ 2 b  }# W2 a+ D
where firstname = ‘May’;8 p" d) o  w; n& h) K* X
, |/ J( m0 [% f- P
% J% J5 W8 v2 @' D3 _
查询所有名称为May的行。
作者: ilikenba    时间: 2004-10-19 14:55
<>现在的数据库程序开发最好要使用SQL语句来做,也就是要将一些数据库的操作交给数据库来处理,这样可以很大的提高效率!</P>
作者: caomeixiong    时间: 2005-7-17 20:04
<>谢谢楼上</P>
作者: spaceboy    时间: 2005-7-18 17:41
谢谢楼主
作者: single    时间: 2005-8-17 17:52
<>只是无从下手呀</P>
作者: fuxiaoso    时间: 2005-9-27 10:11
看不懂
作者: park477    时间: 2005-10-8 09:59
好贴
作者: park477    时间: 2005-10-8 09:59
收藏了
作者: liumath    时间: 2005-10-9 13:41
Oracle, Sybase, Microsoft SQL Server, Access,VFP,DB2哪个较常用?
作者: madio    时间: 2005-10-9 14:03
<DIV class=quote><B>以下是引用<I>liumath</I>在2005-10-9 13:41:52的发言:</B><BR>Oracle, Sybase, Microsoft SQL Server, Access,VFP,DB2哪个较常用?</DIV>
: ?, E( P! _+ Z( y/ z* o<br>access用的多!
作者: 西门小鱼    时间: 2005-10-12 14:39
支持!
作者: rainbird    时间: 2006-6-29 09:14
<p>顶一顶!</p>
作者: hhh2008cs    时间: 2007-1-9 15:48
<p>非常感谢!</p>
作者: bukater    时间: 2007-3-29 19:59
还是SQL好,有本事远程acess试试看
作者: HelloDan    时间: 2007-5-10 01:35
谢了。
作者: Appally    时间: 2007-6-20 22:56
<p>精典</p><p></p>
作者: Q宝贝    时间: 2007-8-23 00:59
[em07] 不错啊,谢谢楼主
作者: Z.junyuan    时间: 2012-7-2 21:28
挺好的,就是少了点。能不能请楼主共享一本关于SQL方面的书捏?




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5