1.autoCommit()、commit()、rollback()php
function autoCommit($onoff=false)
指定是否自动提交事务。有的后端数据库不支持。
function commit()
提交当前事务
function rollback()
回滚当前事务mysql
对于这三个数据库事务,还不是很理解,先记录下实例sql
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:$password@$hostName/$dbName"; 20 $db = DB::connect($dsn); 21 */ 22 $db = & DB::connect('mysql://root:a12345@localhost/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(原子性):事务中包含的操做被看作一个逻辑单元,这个逻辑单元中的操做要么所有成功,要么所有失败。fetch
● Consistency(一致性):只有合法的数据能够被写入数据库,不然事务应该将其回滚到最初状态。ui
● Isolation(隔离性):事务容许多个用户对同一个数据进行并发访问,而不破坏数据的正确性和完整性。同时,并行事务的修改必须与其余并行事务的修改相互独立。spa
● 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 语句也会被彻底回滚)。