表和视图 ; p2 g i' m( u
$ j c# o. z S# `2 ?. v2 F Oracle中表是数据存储的基本结构。ORACLE8引入了分区表和对象表,ORACLE8i引入了临时表,使表的功能更强大。视图是一个或多个表中数据的逻辑表达式。本文我们将讨论怎样创建和管理简单的表和视图。
; N. }2 q5 ~0 L+ ^7 }8 P
$ O$ a! a! u0 X 管理表
- v5 E, I% y+ K1 y" D0 C
$ C! E& O5 I+ e6 F1 M 表可以看作有行和列的电子数据表,表是关系数据库中一种拥有数据的结构。用CREATE TABLE语句建立表,在建立表的同时,必须定义表名,列,以及列的数据类型和大小。例如:
1 \ k. \% t9 t+ L& {) R' M/ l j4 x7 o' ~, U
CREATE TABLE products 5 j$ c2 c5 [5 ^2 @4 S' p
( PROD_ID NUMBER(4), ' W' [ W( F" t/ R
PROD_NAME VAECHAR2(20), ' Q$ z3 A( [: C- t) ^
STOCK_QTY NUMBER(5,3) * Q3 E b4 B% @8 ^ r/ {: k
); / S5 X# r8 i( y! a) x+ @
' }* y6 f; l* ^* S: O2 \ 这样我们就建立了一个名为products的表, 关键词CREATE TABLE后紧跟的表名,然后定义了三列,同时规定了列的数据类型和大小。 W! c7 }: J" v9 B' @* q
1 L( P' x1 \5 w' ]4 h 在创建表的同时你可以规定表的完整性约束,也可以规定列的完整性约束,在列上普通的约束是NOT NULL,关于约束的讨论我们在以后进行。
% n# K; i/ m7 _# @' _- J
8 ]1 M9 q' u4 V6 d8 ~ 在建立或更改表时,可以给表一个缺省值。缺省值是在增加行时,增加的数据行中某一项值为null时,oracle即认为该值为缺省值。
( } ?3 K9 `, r! ?# Y+ ^2 E6 M
* s. T/ D- e+ |: ~4 [ 下列数据字典视图提供表和表的列的信息:
: b; q1 f' F# d
# M, `3 H$ h5 S; R, B . DBA_TABLES ; T# R% E& T3 ]8 C2 v4 A
. DBA_ALL_TABLES : t ?/ _- X9 q$ S2 q4 I$ C+ }' I
. USER_TABLES
9 M: v. D X8 j+ p* m2 V4 q7 I . USER_ALL_TABLES
4 h. P6 K% H) B: N . ALL_TABLES
7 z9 u8 z. M& v4 D5 X; {* s/ f . ALL_ALL_TABLES & y" ]2 m# ^3 u; {# F
. DBA_TAB_COLUMNS
6 J$ H/ e) {, a8 C- R: f . USER_TAB_COLUMNS
# |8 g4 H) t! N. p5 r . ALL_TAB_COLUMNS
/ a9 H* E$ Q8 e- Q
, [# X; P. X" }$ I 表的命名规则 ) T4 E+ o2 [0 z" h0 F" Y
$ w: U: f/ h. @1 q D. z1 D7 B
表名标识一个表,所以应尽可能在表名中描述表,oracle中表名或列名最长可以达30个字符串。表名应该以字母开始,可以在表名中包含数字、下划线、#、$等。 # B6 I; i$ q3 X- L
5 g' `+ A! g8 b% k3 c 从其它表中建立表 ) s4 d- y8 W/ p3 T9 P& h
0 q4 K$ N; o9 m5 ^- C5 N# C8 w
可以使用查询从基于一个或多个表中建立表,表的列的数据类型和大小有查询结果决定。建立这种形式的表的查询可以选择其他表中所有的列或者只选择部分列。在CREATE TABLE语句中使用关键字AS,例如: : H: e( o, c$ E1 o' t
. w* ~+ u- }: R5 Z9 f5 B: \% sSQL>CREATE TABLE emp AS SELECT * FROM employee
8 ~/ o) q' n8 E+ R0 n9 o& S9 Z& \, u; o# ?( i8 G5 s$ @- k J
TABLE CREATED & B: x( B" F: j
i9 m0 H; j" s, FSQL> CREATE TABLE Y AS SELECT * FROM X WHERE no=2
; ^( ]& P6 O o6 u4 {
, g5 @3 v5 c% ]7 z0 h- O 需要注意的是如果查询涉及LONG数据类型,那么CREATE TABLE....AS SELECT....将不会工作。 0 g" L$ W& v( h. c
t6 I: H* X1 S: U' J7 [ 更改表定义 5 E5 |8 a! `# c2 B& U. F$ {
$ c! h' @6 s# u' R% _# K
在建立表后,有时候我们可能需要修改表,比如更改列的定义,更改缺省值,增加新列,删除列等等。ORACLE使用ALTER TABLE语句来更改表的定义 , k7 P, {' h _! {8 X
) E8 q3 W: i& b* A% [
1、增加列 7 N2 H4 {) C6 B* g0 Z Q9 }
" P) P _' p+ \" r+ G 语法: 0 n4 ~& K+ x$ Q% r8 N1 F8 S4 r
) i" _+ O6 A- ?4 J/ `ALTER TABLE [schema.] table_name ADD column_definition
0 v0 @! k* E5 Q* I+ \( }
( a/ y: W0 H4 X$ k 例: ; D8 e' O0 h0 L, {% O( }! t
; `0 }' l0 M$ U2 A! F0 L
ALTER TABLE orders ADD order_date DATE;
5 a2 x8 e0 P0 s5 G- U3 u- b% _8 ^' ]& J
TABLE ALTER * j% x! \/ A: {3 I. U$ K
4 o; ]4 {: `7 }
对于已经存在的数据行,新列的值将是NULL. . |3 T3 N* V, p
2、更改列 * O' i4 `3 s' I- u* Z3 U
# z$ z ~# c3 H% H8 ^2 v; [2 a9 G1 Q 语法: , Z; b+ d6 Z: x2 r
8 u; h/ H, M$ @' J$ c V4 u1 U6 GALTER TABLE [schema.] table_name MODIFY column_name new_attributes; 8 X6 v0 b& r* {! A
) L! b. s+ N9 ^# u1 d
例:
8 Q" a) @; ?- i J! t+ r/ c0 }* |; ?* ?0 W
ALTER TABLE orders MODITY (quantity number(10,3),status varchar2(15));
2 ]$ z# X1 s, j
8 h% L. g0 u5 N% I* _' v 这个例子中我们修改了表orders,将STATUS列的长度增加到15,将QUANTITY列减小到10,3;
9 x5 r2 C8 `. D5 x- R" h2 x; ]! A
修改列的规则如下: , j$ f. X6 T6 q
& E J/ y& O2 K* P% X6 Y
. 可以增加字符串数据类型的列的长度,数字数据类型列的精度。
$ A6 u: {, s+ i# j: j; x/ B! O2 \" m8 F& _- K3 m
. 减少列的长度时,该列应该不包含任何值,所有数据行都为NULL.
( B4 s: q( V( c2 ?! E# H. ~" k+ [: y. t7 j1 s
. 改变数据类型时,该列的值必须是NULL. ! v: k' W0 K! j/ ?- G+ M# A
1 \. @1 Q' t% e. B7 M$ |; u- N% Y . 对于十进制数字,可以增加或减少但不能降低他的精度。
' R2 s4 ?# m/ C; Z% B; k! ?+ t. c( T9 s5 l, I- b* M7 Y
|