2.DELETE (删除数据表里记录的语句), I$ D0 z7 K0 {9 ^
1 ~* t# k3 s! q7 x1 B
DELETE FROM表名 WHERE 条件;
3 {- f6 O+ e7 N9 K7 }* t& c
' l8 `- [! e% l/ [7 E6 Y/ M5 {注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused.
2 ]' V& b! x# T% e4 }" v# V9 z( [6 i6 F4 F1 W
如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间
$ Z7 x7 ^4 } l7 f8 y0 E9 _6 q; ^TRUNCATE TABLE 表名;
7 \( s& ^' |* R. G此操作不可回退." C3 }/ B+ j( T; f. i& u' V
* s5 ]- o& M& n9 S$ g
3.UPDATE (修改数据表里记录的语句)
+ h8 j1 ]. r( Z1 y. E2 M8 M! o5 e7 _* P! g
UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 条件;
1 U _; a. ]9 q, y/ Y5 L
3 C. V! l9 A$ X4 [* |4 h+ g如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验;
! X0 b: ]& ^, N值N超过定义的长度会出错, 最好在插入前进行长度校验..6 |! A: D$ e9 H# E2 T. @: n
6 J5 D$ ]6 c9 L, v注意事项:: @: w7 y r! B
A. 以上SQL语句对表都加上了行级锁,
7 C ?4 ~5 L+ ~; k 确认完成后, 必须加上事物处理结束的命令 COMMIT 才能正式生效,
' r* E: \; Q* r0 X, q7 N 否则改变不一定写入数据库里. m& D4 m2 j5 K9 e. v
如果想撤回这些操作, 可以用命令 ROLLBACK 复原.
$ }+ d- Y2 v# ^5 n* a' K5 _# {4 I! n' e( o% i1 I
B. 在运行INSERT, DELETE 和 UPDATE 语句前最好估算一下可能操作的记录范围,6 V }4 d& ~. H9 G9 }
应该把它限定在较小 (一万条记录) 范围内,. 否则ORACLE处理这个事物用到很大的回退段.
?3 x; r, G J* A% n% y 程序响应慢甚至失去响应. 如果记录数上十万以上这些操作, 可以把这些SQL语句分段分次完成,
) ]: S+ H: p) h! E 其间加上COMMIT 确认事物处理. |