Oracle数据操作和控制语言详解(二)

原创 2004年07月31日 16:38:00
事务控制

  事务控制包括协调对相同数据的多个同步的访问。当一个用户改变了另一个用户正在使用的数据时,oracle使用事务控制谁可以操作数据。

  事务

  事务表示工作的一个基本单元,是一系列作为一个单元被成功或不成功操作的SQL语句。在SQL和PL/SQL中有很多语句让程序员控制事务。程序员可以:

   1、显式开始一个事物,选择语句级一致性或事务级一致性

   2、设置撤销回滚点,并回滚到回滚点
 
   3、完成事务永远改变数据或者放弃修改。
  
  事务控制语句

语句 用途
Commit 完成事务,数据修改成功并对其他用户开放
Rollback 撤销事务,撤销所有操作
rollback to savepoint 撤销在设置的回滚点以后的操作
set transaction 响应事务或语句的一致性;特别对于事务使用回滚段

  例:

BEGIN
UPDATE checking
SET balance=balance-5000
WHERE account='Kieesha';

INSERT INTO checking_log(action_date,action,amount)
VALUES (SYSDATE,'Transfer to brokerage',-5000);

UPDATE brokerage
SET cash_balance=cash_balance+5000
WHERE account='Kiesha';

INSERT INTO brokerage_log(action_date,action,amount)
VALUES (SYSDATE,'Tracfer from checking',5000)

COMMIT

EXCEPTION
WHEN OTHERS
ROLLBACK

END

  Savepoint 和 部分回滚(Partial Rollback)

  在SQL和PL/SQL中Savepoint是在一事务范围内的中间标志。经常用于将一个长的事务划分为小的部分。保留点Savepoint可标志长事务中的任何点,允许可回滚该点之后的操作。在应用程序中经常使用Savepoint;例如一过程包含几个函数,在每个函数前可建立一个保留点,如果函数失败,很容易返回到每一个函数开始的情况。在回滚到一个Savepoint之后,该Savepoint之后所获得的数据封锁被释放。为了实现部分回滚可以用带TO Savepoint子句的ROLLBACK语句将事务回滚到指定的位置。

  例

BEGIN

INSERT INTO ATM_LOG(who,when,what,where)
VALUES ('Kiesha',SYSDATE,'Withdrawal of $100','ATM54')
SAVEPOINT ATM_LOGGED;

UPDATE checking
SET balance=balance-100
RETURN balance INTO new_balance;

IF new_balance<0
THEN
ROLLBACK TO ATM_LOGGED;
COMMIT
RAISE insufficient_funda;
END IF

END

  关键字SAVEPOINT是可选的,所以下面两个语句是等价的:

ROLLBACK TO ATM_LOGGED;
ROLLBACK TO SAVEPOINT ATM_LOGGED;

  一致性和事务

  一致性是事物控制的关键慨念。掌握了oracle 的一致性模型,能使您更好的,更恰当的使用事务控制。oracle通过一致性保证数据只有在事务全部完成后才能被用户看见和使用。这项技术对多用户数据库有巨大的作用。

  oracle常常使用语句级(state-level)一致性,保证数据在语句的生命期之间是可见的但不能被改变。事务由多个语句组成,当使用事务时,事物级(transaction-level)一致性在整个事务生命期中保证数据对所有语句都是可见的。

  oracle通过SCN(syatem change number)实施一致性。一个SCN是一个面向时间的数据库内部键。SCN只会增加不会减少,SCN表示了时间上的一个点,每个数据块都有一个SCN,通过比较这个点实施操作。

  事务级一致性

  SET TRANSACTION 的一个作用是确保事务级一致或语句级一致中有一个实施。ORACLE使用这些术语:

   ISOLATION LEVEL READ COMMIT 表示语句级一致

   ISOLATION LEVEL SERIALIZABLE 表示事务级一致。

  例:

SET TRANSACTION ISOLATION LEVEL READ COMMIT;

SET TRANSACTION ISOLATION LEVEL READ COMMIT

  下面的语句也能确保事务级一致:

SET TRANSCATION READ ONLY

  任何企图在只读(READ ONLY)事务中修改数据的操作都会抛出一个异常。但是,READ ONLY事务只能在下列语句中使用:

SELECT(没有FOR UPDATE子句)
LOCK TABLE
SET ROLE
ALTER SYSTEM
ALTER ALARM

  即使没有改变任何数据,READ ONLY事务依然必须使用一个COMMIT或ROLLBACK以结束整个事务。

  SET TRANSCTION的另外一个应用是在回滚时直接使用回滚段(ROLLBACK SEGMENT)。回滚段是ORACLE的一个特殊的数据对象,回滚段的头部包含正在使用该回滚段事务的信息。当用户回滚事务(ROLLBACK)时,ORACLE将会利用回滚段中的数据前影像来将修改的数据恢复到原来的值。oracle用round-robin给事务随机分配回滚段。一个大的事务可以分配任何回滚段,这也许会导致回滚段的大小变得很大。因此要避免让大的事务随机分配回滚段。

  事务以SET TRANSACTION开始,象下面这样:

SET TRANSACTION USE ROLLBACK SEGMENT rb_large;

  rb_large是一个大的回滚段的名称,现在就给一个大的事务分配了一个大的回滚段,其他的小的回滚段将不由动态空间管理,这样就更有效率。

  下面我们看一个例子.我们有一个回滚段表空间大小是2G,在高峰时期需要10个回滚段以满足用户的需要,这些高峰在线用户只有小的事务。一周我们连续运行了4个大的事务,这些事务需要删除和加载数据,每一个撤销需要1G,回滚段的大小如下:

rb_large(initial 100M minextenta 2)

rb1 (initial 1M next minextents 5)
rb2 (initial 1M next minextents 5)
rb3 (initial 1M next minextents 5)
rb4 (initial 1M next minextents 5)
rb5 (initial 1M next minextents 5)
rb6 (initial 1M next minextents 5)
rb7 (initial 1M next minextents 5)
rb8 (initial 1M next minextents 5)
rb9 (initial 1M next minextents 5)
rb10 (initial 1M next minextents 5)

  所有的都非常恰当的安排在2G的表空间中,如果我们缺省的round-robin给事务分配回滚段,4个大事务将有4个独立的回滚段,每个回滚段的大小将是1G,如果这样我们的2G表空间就不够,而数据库管理员就不得不在夜晚2点起来工作,每个事务都由以下面的语句开始:

SET TRANSACTION USE ROLLBACK SEGMENT rb_large

  现在 4个事务重用相同的表空间,保正4个回滚段的表空间在2G以内。数据库管理员可以睡到天亮。

Oracle数据操作和控制语言详解

SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML, 数据定义语言DDL,数据控制语言DCL。其中用于定义数据的结构,比如 创建、修改或者删除数据库;DCL用于定义数据库用户的权限;在这篇...
  • xuan_xinya
  • xuan_xinya
  • 2013年04月03日 07:33
  • 1532

Oracle数据操作和控制语言详解

对于SQL语言,有两个组成部分:DML、DDL DML(data manipulation language):它们是SELECT、UPDATE、INSERT、DELETE,就象它的名字一样,这4条...
  • jackpk
  • jackpk
  • 2013年04月17日 07:58
  • 2428

Oracle SQL数据操作和查询(二)

Oracle SQL数据操作和查询 高级查询,集合运算,连接查询,外联接(+)=
  • xingbao1
  • xingbao1
  • 2015年10月15日 15:42
  • 121

Opencv--形态学图像处理--膨胀与腐蚀,开操作与闭操作

opencv 膨胀与腐蚀,开操作与闭操作
  • l740450789
  • l740450789
  • 2015年08月05日 12:00
  • 2974

MySQLi实现数据库操作的预处理

1、预处理是为了什么? 我们在查数据库时,有时要用到一些结构相同,只有参数不同的SQL语句,使用预处理这种方式,可以让我们在查询数据库的时候,提高速度。 2、预处理是怎样提高查询速度的? 通常我...
  • aa1600159112
  • aa1600159112
  • 2015年11月05日 15:02
  • 633

Oracle SQL数据操作和查询(一)

Oracle数据库的基础知识简单查询,数据插入,更新数据,删除数据,操作符
  • xingbao1
  • xingbao1
  • 2015年10月15日 15:23
  • 186

二、SQL数据操作和查询

一、SQL简介 SQL是结构化查询语言(Structured Query Language),专门用于数据存取、数据更新及数据库管理等操作。 在Oracle开发中,客户端把SQL语句发送给服务器,服务...
  • jkaies
  • jkaies
  • 2013年09月02日 14:12
  • 442

Oracle的并发控制

并发访问带来的问题 丢失更新:一个事务修改某行数据时,另一个事务同时修改了该行数据,使第一个事务对数据的修改丢失。 脏读:一个事务读取了另一个事务未提交的数据。 不可重复读:一个事务...
  • qq_30398499
  • qq_30398499
  • 2017年05月17日 14:12
  • 315

ORACLE 操作和管理表

Sql代码   数据库对象:   :: Table:存储数据   :: View:来自一个或多个表的数据的子集   :: Sequence:数字值发生器   :: Index:改...
  • u012113911
  • u012113911
  • 2014年07月30日 22:35
  • 397

6-3DBMS并发控制

6-3DBMS并发控制tags:数据库 事务是并发控制的基本单位,保证事务的ACID特性是事务处理的重要人物,而事务的ACID特性可能遭到破坏的原因之一是多个事务对数据库的并发操作造成的,为了保证...
  • qq_22841811
  • qq_22841811
  • 2016年06月30日 13:18
  • 428
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Oracle数据操作和控制语言详解(二)
举报原因:
原因补充:

(最多只允许输入30个字)