a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 84|回复: 0

[综合] Oracle数据库常用sql语句汇总2

[复制链接]
发表于 2012-8-4 13:54:49 | 显示全部楼层 |阅读模式
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 确认事物处理.
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-5-3 10:23 , Processed in 0.164744 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表