PEAR DB 事务相关

1.autoCommit()、commit()、rollback()

function autoCommit($onoff=false) 
指定是否自动提交事务。有的后端数据库不支持。

function commit() 
提交当前事务

function rollback() 
回滚当前事务

对于这三个数据库事务,还不是很理解,先记录下实例

 1 <?php
 2 /**
 3  * Created by PhpStorm.
 4  * User: ${Darlin}
 5  * Date: 2015/11/17
 6  * Time: 14:37
 7  */
 8
 9
10 //引入PDB库
11 require_once("DB.php");
12 //设定访问的数据库、登录名、密码、主机
13 /*
14 $userName = ‘root‘;
15 $password = ‘a12345‘;
16 $hostName = ‘localhost‘;
17 $dbName = ‘db_chengxl‘;
18 //设定DSN参数,并进行数据库链接,我连接的数据库为Mysql
19 $dsn = "mysql://$userName:[email protected]$hostName/$dbName";
20 $db = DB::connect($dsn);
21 */
22 $db = & DB::connect(‘mysql://root:[email protected]/db_chengxl‘);
23 //错误处理
24 if (DB::isError($db)) {
25     die ($db->getMessage());
26 }
27
28 //Using autocommit()
29 /*
30 $db->autoCommit(false);
31
32 $db->query(‘CREATE TABLE blah (a integer)‘);
33 $db->query(‘CREATE TABLE blue (b integer)‘);
34 $db->commit();
35
36 $db->query(‘INSERT INTO blah (a) VALUES (11)‘);
37 $db->query(‘INSERT INTO blah (a) VALUES (12)‘);
38 $db->commit();
39
40 $res1 =& $db->query(‘SELECT a FROM blah‘);
41 if (DB::isError($res1)) {
42     echo $res1->getMessage() . "\n";
43 }
44 $i = 1;
45 while ($res1->fetchInto($row, DB_FETCHMODE_ORDERED)) {
46     echo "fetch data $row[0]\n";
47     echo "insert number $i...\n";
48     $res2 =& $db->query("INSERT INTO blue (b) VALUES ($i)");
49     if (DB::isError($res2)) {
50         echo $res2->getMessage() . "\n";
51     }
52     $i++;
53 }
54 $res1->free();
55 //销毁
56 ////delete table删除表的数据,表仍然存在,仍可以对表进行操作。
57 //同样,还有一个TRUNCATE TABLE TABLENAME语句,也是删除数据,表仍然存在。
58 //drop table,是从数据库中删除表。删除后,表结构不在存在,无法再对该表进行任何操作。
59
60 $db->query(‘DROP TABLE blah‘);
61 $db->query(‘DROP TABLE blue‘);
62 $db->commit();
63 */
64
65 //Using rollback()
66 $db->autoCommit(false);
67 $db->query(‘CREATE TABLE blah (a integer)‘);
68 $db->query(‘INSERT INTO blah (a) VALUES (11)‘);
69 $res =& $db->query(‘SELECT b FROM blue‘);
70 if (DB::isError($res)) {
71     echo $res->getMessage() . "\n";
72 }
73 while ($res->fetchInto($row, DB_FETCHMODE_ORDERED)) {
74     if ($row[0] == ‘problem‘) {
75         $db->rollback();
76     }
77     echo "123</br>";
78 }
79 $res->free();
80
81 //$db->query(‘DROP TABLE blah‘);
82 $db->commit();
83
84
85
86 ?>

什么是事务?

事务(Transaction)是并发控制的基本单位。所谓的事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位。例如,银行转账工作:从一个账号扣款并使另一个账号增款,这两个操作要么都执行,要么都不执行。所以,应该把它们看成一个事务。事务是数据库维护数据一致性的单位,在每个事务结束时,都能保持数据一致性。

针对上面的描述可以看出,事务的提出主要是为了解决并发情况下保持数据一致性的问题。

事务具有以下4个基本特征。

●   Atomic(原子性):事务中包含的操作被看做一个逻辑单元,这个逻辑单元中的操作要么全部成功,要么全部失败。

●   Consistency(一致性):只有合法的数据可以被写入数据库,否则事务应该将其回滚到最初状态。

●   Isolation(隔离性):事务允许多个用户对同一个数据进行并发访问,而不破坏数据的正确性和完整性。同时,并行事务的修改必须与其他并行事务的修改相互独立。

●   Durability(持久性):事务结束后,事务处理的结果必须能够得到固化。

2.事务的语句
 开始事物:BEGIN TRANSACTION
 提交事物:COMMIT TRANSACTION
 回滚事务:ROLLBACK TRANSACTION
3.事务的4个属性
     ①原子性(Atomicity):事务中的所有元素作为一个整体提交或回滚,事务的个元素是不可分的,事务是一个完整操作。
  ②一致性(Consistemcy):事物完成时,数据必须是一致的,也就是说,和事物开始之前,数据存储中的数据处于一致状态。保证数据的无损。
  ③隔离性(Isolation):对数据进行修改的多个事务是彼此隔离的。这表明事务必须是独立的,不应该以任何方式以来于或影响其他事务。
  ④持久性(Durability):事务完成之后,它对于系统的影响是永久的,该修改即使出现系统故障也将一直保留,真实的修改了数据库
4.事务的保存点
     SAVE TRANSACTION 保存点名称 --自定义保存点的名称和位置
     ROLLBACK TRANSACTION 保存点名称 --回滚到自定义的保存点

其他高手的一些补充:

事务的标准定义: 指作为单个逻辑工作单元执行的一系列操作,而这些逻辑工作单元需要具有原子性,  一致性,隔离性和持久性四个属性,统称为ACID特性。

所谓事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。例如,在关系数据库中,一个事务可以是一条SQL语句、一组SQL语句或整个程序。 
事务和程序是两个概念。一般地讲,一个程序中包含多个事务。
事务的开始与结束可以由用户显式控制。如果用户没有显式地定义事务,则由DBMS按缺省规定自动划分事 
务。在SQL语言中,定义事务的语句有三条: 
BEGIN TRANSACTION 
COMMIT 
ROLLBACK

同生共死。。
显示事务被用begin transaction 与 end transaction 标识起来,其中的 update 与 delete 语句或者全部执行或者全部不执行。。 如:
begin transaction T1
update student
set name=‘Tank‘
where id=2006010
delete from student
where id=2006011
commit
简单地说,事务是一种机制,用以维护数据库的完整性。

其实现形式就是将普通的SQL语句嵌入到Begin Tran...Commit Tran 中(或完整形式 Begin Transaction...Commit Transaction),当然,必要时还可以使用RollBack Tran 回滚事务,即撤销操作。

利用事务机制,对数据库的操作要么全部执行,要么全部不执行,保证数据库的一致性。需要使用事务的SQL语句通常是更新和删除操作等。

end transaction T1

关于savepoint

用户在事务(transaction)内可以声明(declare)被称为保存点(savepoint)
的标记。保存点将一个大事务划分为较小的片断。

用户可以使用保存点(savepoint)在事务(transaction)内的任意位置作标
记。之后用户在对事务进行回滚操作(rolling back)时,就可以选择从当前
执行位置回滚到事务内的任意一个保存点。例如用户可以在一系列复杂的更
新(update)操作之间插入保存点,如果执行过程中一个语句出现错误,用
户 可以回滚到错误之前的某个保存点,而不必重新提交所有的语句。

在开发应用程序时也同样可以使用保存点(savepoint)。如果一个过程
(procedure)内包含多个函数(function),用户可以在每个函数的开始位置
创建一个保存点。当一个函数失败时, 就很容易将数据恢复到函数执行之前
的状态,回滚(roll back)后可以修改参数重新调用函数,或执行相关的错误
处理。

当事务(transaction)被回滚(rollback)到某个保存点(savepoint)后,
Oracle将释放由被回滚语句使用的锁。其他等待被锁资源的事务就可以继续
执行。需要更新(update)被锁数据行的事务也可以继续执行。

将事务(transaction)回滚(roll back)到某个保存点(savepoint)的过程如
下:
1. Oracle 回滚指定保存点之后的语句
2. Oracle 保留指定的保存点,但其后创建的保存点都将被清除
3. Oracle 释放此保存点后获得的表级锁(table lock)与行级锁(row
lock),但之前的数据锁依然保留。

被部分回滚的事务(transaction)依然处于活动状态,可以继续执行。

一个事务(transaction)在等待其他事务的过程中,进行回滚(roll back)到
某个保存点(savepoint)的操作不会释放行级锁(row lock)。为了避免事务
因为不能获得锁而被挂起,应在执行 UPDATE 或 DELETE 操作前使用 FOR
UPDATE ... NOWAIT 语句。(以上内容讲述的是回滚保存点之前所获得的
锁。而在保存点之后获得的行级锁是会被释放的,同时保存点之后执行的
SQL 语句也会被完全回滚)。

时间: 2024-10-12 22:30:05

PEAR DB 事务相关的相关文章

oracle数据库事务相关【weber出品必属精品】

事务的概念:事务:一个事务由一组构成一个逻辑操作的DML语句组成 事务有开始有结束,事务以DML语句开始,以Conmmit和Rollback结束.以下情况会使得事务结束: 1. 执行COMMIT 或者 ROLLBACK 语句 2. 执行DDL或者 DCL语句 3. 用户退出 4. 系统崩溃 一个事务可以包含下列语句: 1. 对数据做出一致性修改的DML语句 2. 一个 DDL 语句 3. 一个 DCL语句 DDL与和DCL语句执行的过程: 1. 首先发出COMMIT; 2. 执行对数据字典的DM

MySQL学习笔记-事务相关话题

事务机制 事务(Transaction)是数据库区别于文件系统的重要特性之一.事务会把数据库从一种一致状态转换为另一个种一致状态.在数据库提交工作时,可以确保其要么所有修改都已经保存了,要么所有修改都不保存. InnoDB存储引擎中的事务完全符合ACID的特性. 原子性(atomicity) 原子性是指整个数据库事务是不可分割的工作单位.只有使事务中所有的数据库操作执行都成功,才算整个事务成功.如果事务中任何一个SQL语句执行失败,那么已经执行成功的SQL语句也必须撤销,数据库状态应该退回到执行

Spring 事务相关点整理

Spring和事务的关系 关系型数据库.某些消息队列等产品或中间件称为事务性资源,因为它们本身支持事务,也能够处理事务. Spring很显然不是事务性资源,但是它可以管理事务性资源,所以Spring和事务之间是管理关系. 就像起码很多领导虽然不会写代码,但是他却管理着一大批会写代码的码农. Spring事务三要素 数据源:表示具体的事务性资源,是事务的真正处理者,如MySQL等. 事务管理器:像一个大管家,从整体上管理事务的处理过程,如打开.提交.回滚等. 事务应用和属性配置:像一个标识符,表明

Spring事务相关记录

一.注解事务的使用: <!-- 数据源 --> <bean id="dataSource" class="org.apache.tomcat.jdbc.pool.DataSource" destroy-method="close"> <property name="driverClassName" value="${db.driverClassName}" /> <

CI源码分析(三)—DB事务

(0) 使用方法 可以使用系统提供的方法: $this->db->trans_start(); // 开始事务 $this->db->query(); // 执行sqls $this->db->trans_complete(); // 结束事务(不需要关心是否回滚) if !$this->db->trans_status do something; // 错误处理 也可以自己处理commit和rollback: $this->db->trans_

事务相关知识(传播特性,隔离级别,锁)

上接 : EJB事务控制(CMT和BMT两种方式以及JTA事务) 上篇代码: @TransactionAttribute(TransactionAttributeType.REQUIRED)  //设置事务的传播特性为required 上篇文章为什么设置传播特性为: required? 事务的传播特性有7个: 1. PROPAGATION_REQUIRED: 如果存在一个事务,则支持当前事务.如果没有事务则开启       2. PROPAGATION_SUPPORTS: 如果存在一个事务,支持

Spring 事务相关

事务类型 数据库事务类型有本地事务和分布式事务: 本地事务:就是普通事务,能保证单台数据库上的操作的ACID,被限定在一台数据库上: 分布式事务:涉及两个或多个数据库源的事务,即跨越多台同类或异类数据库的事务(由每台数据库的本地事务组成的),分布式事务旨在保证这些本地事务的所有操作的ACID,使事务可以跨越多台数据库: Java事务类型有JDBC事务和JTA事务: JDBC事务:就是数据库事务类型中的本地事务,通过Connection对象的控制来管理事务: JTA事务:JTA指Java事务API

分布式事务相关资料

1.tcc-transaction源码地址 tcc-transaction https://github.com/changmingxie/tcc-transaction 2.TCC事务机制简介 http://www.bytesoft.org/2017/03/29/tcc/ 3.ByteJTA源码地址 https://github.com/liuyangming/ByteJTA/ 4.深入理解分布式事务 http://www.cnblogs.com/biakia/p/6195142.html 5

SQL Server 连接和事务相关的问题。

方法 1. dbcc opentran + sys.dm_exec_connections dbcc opentran; 可以看到最旱的活动事务是 54 这个session 发起的.下面看一下它做了点什么. select conn.session_id,sess.program_name,sqltext.text      from sys.dm_exec_connections as conn cross apply sys.dm_exec_sql_text(conn.most_recent_