1、事务概念:
概念:在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么完全成功执行,完成整个工作单元操作,要么一点也不执行。
主要特性:确保数据库的完整性。
2、事务的ACID特性
对一组SQL语句操作构成事务,数据库操作系统必须确保这些操作的原子性,一致性,隔离性,持久性.
1、 原子性(Atomicity)
事务的原子性是指事务中包含的所有操作要么全做,要么不做,也就是说所有的活动在数据库中要么全部反映,要么全部不反映,以保证数据库的一致性。
2、 一致性(Consistency)
事务的一致性是指数据库在事务操作前和事务处理后,其中数据必须满足业务的规则约束。
3、 隔离性(Isolation)
隔离性是指数据库允许多个并发的事务同时对其中的数据进行读写或修改的能力,隔离性可以防止多个事务的并发执行时,由于它们的操作命令交叉执行而导致数据的不一致性。
4、 持久性(durability)
事务的持久性是指在事务处理结束后,它对数据的修改应该是永久的。即便是系统在遇到故障的情况下也不会丢失,这是数据的重要性决定的。
3、事务的控制语句
在oracle数据库中,没有提供开始事务处理语句,所有的事务都是隐式开始的,也就是说在oracle中,用户不可以显示使用命令来开始一个事务.oracle任务第一条修改数据库的语句,或者一些要求事务处理的场合都是事务的隐式开始。但是当用户想要终止一个事务处理时,必须显示使用commit和rollback语句结束。
根据事务ACID属性,oracle提供了如下的事务控制语句:
Set transaction 设置事物属性
Set constrains 设置事物的约束模式
约束模式是指:在事务中修改数据时,数据库中的约束立即应用于数据,还是将约束推迟到当前事务结束后应用。
Savepoint 在事务中建立一个存储的点.当事务处理发生异常而回滚事务时,可指定事务回滚到某存储点.然后从该存储点重新执行。
Release savepoint 删除存储点
Rollback 回滚事务 取消对数据库所作的任何操作
Commit 提交事务 对数据库的操作做持久的保存。
3、1设置事物的属性:
set transaction语句可用来设置事物的各种属性。该语句必须放在事务处理的第一个语句.
也就是说,必须在任何insert、update 、delete语句以及其他的事务处理。
Set transaction的语句可以让用户对事务的以下属性进行设置
指定事务的隔离层
规定回滚事务所使用的存储空间
命名事务
备注:在使用set transaction语句设置属性时,对于规定回滚事务所使用的存储空间的设置很少使用.对于命名事务也非常简单,只有在分布式事务处理中才会体现出命名事务的用途.
注意:set transaction只对当前事务有效,事务终止,事务当前的设置将会失效。
1、 数据异常
事务的隔离性定义了一个事务与其它事务的隔离程度.为了更好的理解隔离层,首先讨论一下并发事务对同一个数据库进行访问可能发生的情况.在并发事务中总体来说会发生如下3种情况
错读 |脏读
非重复读取|不可重复读
假读|幻读
错读|脏读:当一个事务修改数据时,另一事务读取了该数据,但是第一事务由于某种原因取消对数据修改,使数据返回了原状态,这是第二个事务读取的数据与数据库中数据不一致.这就叫错读。
非重复读取:是指一个事务读取数据库中的数据后,另一个事务则更新了数据,当第一个事务再次读取其中的数据时,就会发现数据已经发生了改变,这就是非重复读取。非重复读取所导致的结果就是一个事务前后两次读取的数据不相同。
假读:如果一个事务基于某个条件读取数据后,另一个事务则更新了同一个表中的数据,这时第一个事务再次读取数据时,根据搜索的条件返回了不同的行,这就是假读。
事务中遇到的这些异常与事务的隔离性设置有关,事务的隔离性设置越多,异常就出现的越少,但并发效果就越低,事务的隔离性设置越少,异常出现的越多,并发效果越高。
2、 选择隔离层
针对3中读取的数据时产生的不一致现象,在ANSI SQL标准92中定义了4个事务的隔离级别.如下图所示:
隔离层 错读|脏读 非重复读取|不可重复读 假读|幻读
READ UNCOMMITTED(非提交读) 是 是 是
READ COMMITTED(提交读) 否 是 是
Repeatable READ(可重复读) 否 否 是
Serializable(串行读) 否 否 否
Oracle支持上述四种隔离层中的两种:read committed 和serializable。除此之外oralce中还定义read only 和 read write隔离层。
Read committed 这是oracle默认的隔离层。
Serializable:设置事物的隔离层位它时,事务与事务之间完全隔开,事务以串行的方式执行,这并不是说一个事务必须结束才能启动另外一个事务,而是说这些事务的执行的结果于一次执行的事务的结果一致。
Read only和 read write 当使用read only时,事务中不能有任何修改数据库中数据的操作语句,这包括 insert、update、delete、create语句。Read only是serializable的一个子集,区别是read only 只读,而serialzable可以执行DML操作。Read write它是默认设置,该选项表示在事务中可以有访问语句、修改语句.但不经常使用.
3、 建立set transaction的语句
列举如下:
Set transaction read only
Set transaction read write
Set transaction isolation level read committed
Set transaction isolation level serializable
注意:这些语句是互斥的.即不能够同时设置两个或者两个以上的选项。
4、 结束事务:
什么情况下代表事务的结束呢?
1、 Commit 提交事务
2、 rollback 回滚事务
//只读的案例
SQL> set transaction read only;
Transaction set
SQL> select * from users where username='mj';
USERNAME PASSWORD NAME ADDRESS ZIP
-------------------- -------------------- -------------------- -------------------- -------
mj redarmy 陈红军
SQL> update users set password='123' where username='mj';
update users set password='123' where username='mj'
ORA-01456: 不能在 READ ONLY 事务处理中执行插入/删除/更新操作
//脏读的案例
SQL> set transaction isolation level read committed;
Transaction set
SQL> select * from users where username='mj';
USERNAME PASSWORD NAME ADDRESS ZIP
-------------------- -------------------- -------------------- -------------------- -------
mj redarmy 陈红军
SQL> update users set password='123' where username='mj';
1 row updated
SQL> select * from users where username='mj';
USERNAME PASSWORD NAME ADDRESS ZIP
-------------------- -------------------- -------------------- -------------------- -------
mj 123 陈红军
SQL> rollback;
以上内容归redarmy_chen创建,如需转载请附带出处,如有疑问请发送邮件至redarmy_chen@qq.com
分享到:
相关推荐
Missing artifact com.oracle:ojdbc6:jar:11.2.0.1.0问题解决 ojdbc包pom.xml出错 <!-- oracle数据库驱动 --> <dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>...
* 使用 BETWEEN 进行范围查询:SELECT < 列名 > FROM < 表名 > WHERE < 列名 > BETWEEN < 数值 1 > AND < 数值 2 > * 使用 IN 进行多值查询:SELECT < 列名 > FROM < 表名 > WHERE < 列名 > IN (< 数值 1 >, < 数值 ...
Oracle 9i 纯粹实践入门由安装到编程全程图解<br>安装调试环境: <br><br>Oracle 版本: Oracle 9i 2.0.1.0<br>操作系统: Windows2003 server sp2 + IIS6.0<br>数据库连接类型为: 本地asp.net程序连接本地Oracle数据库...
- URL: `jdbc:oracle:thin:@<host>:<port>:<database>` - **OCI XA Type 2 Driver**: - 类: `oracle.jdbc.xa.client.OracleXADataSource` - URL: `jdbc:oracle:thin:@<host>:<port>:<database>` 4. **修改...
<groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>12.1.0.1-atlassian-hosted</version> </dependency> mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc6 -...
- **创建包含BFILE的表**:`create table <表名>(<字段名> number(<长度>), <bfile字段名> bfile);` - 示例:`create table bfiletest(id number(3), fname bfile);` - **插入BFILE数据**:`insert into <表名> ...
代码名称:Mapx4+vb 6.0实现功能全面的例子 —代码部分<br>作者/收集者:jemen <br><br>开发环境:VB + MapX<br><br>代码介绍:<br><br>下载完成的工程项目文件以及运行所需要的DEMO数据,这是一个实现功能非常完整...
<br>Crlab.Oracle.Data.Access.Components.v6.25.Full.Source<br> Delphi.BCB.BDS.CRS.ccrun<br><br>--------------------------------<br> From: C++ Builder Study <br> Mail: info@ccrun.com<br> Web : ...
硬盘分区表详解(作者:李家芳)<br>Linux下添加硬盘,分区,格式化详解(作者:babo slack.cn)<br>Oracle数据库中分区表的操作方法(作者:丁亚军 blog )<br>如何在Linux中访问硬盘DOS分区、软盘和光盘(作者: 辛...
<br>开发平台:eclipse3.1<br>数据库:Oracle 9i<br>总结中包括:<br>一、该系统主要解决的问题<br>二、功能<br>三、开发中遇到的问题及解决方案<br>四、版本<br>五、总结<br>详细的总结请访问<br>...
开发环境:<br><br>Eclipse3.01+myeclipse3.84+mysql5.0(oracle、ms sqlserver2000)。<br><br>压缩包里包含了所有的组件、源码和SQL脚本以及工程文件。<br><br>这个系统也是花了点时间和精力才做好的,现在把源码给...
<groupId>com.oracle</groupId> <artifactId>ojdbc14</artifactId> <version>10.2.0.4.0</version> </dependency> 安装到仓库 mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc14 -Dversion=...
URL格式:`jdbc:oracle:thin:@<主机>:<端口>:<服务标识符>` 2. DB2数据库: 驱动类:`com.ibm.db2.jdbc.app.DB2Driver` URL格式:`jdbc:db2://<主机>:<端口>/<数据库名>` 3. SQL Server 7.0/2000数据库: 驱动...
<groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>12.1.0.1-atlassian-hosted</version> </dependency> mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc6 -...
- URL格式:`jdbc:oracle:thin:@<主机>:<端口>:<SID>` - 示例:`jdbc:oracle:thin:@localhost:1521:orcl` 2. **DB2** 数据库 - 驱动类:`com.ibm.db2.jdbc.app.DB2Driver` - URL格式:`jdbc:db2://<主机>:<端口...
<groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>12.1.0.1-atlassian-hosted</version> </dependency> mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc6 -...
<groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>12.1.0.1-atlassian-hosted</version> </dependency> mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc6 -...
<groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>12.1.0.1-atlassian-hosted</version> </dependency> mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc6 -...
- URL 格式:`jdbc:oracle:thin:@<hostname>:<port>:<service_name>` - **DB2**: - 驱动类:`com.ibm.db2.jdbc.app.DB2Driver` - URL 格式:`jdbc:db2://<hostname>:<port>/<database_name>` - **SQL Server**...