2月3号笔记,SQL中的事务

作者在 2007-02-04 06:27:00 发布以下内容

事务:
begin transaction       开始事务
commit transaction 提交事务
rollboack transaction 回滚事务

set implicit_ransaction on    隐式事务
update customer set nickname-'nicky'
where customerId=10
这样这条语句不会改变数据,必须在最后加上,commit transaction 才会提交上述事务.
因为我们指明使用隐式事务,所以每一条语句都会当成是一个事务,所以要commit transaction才能提交.


事务完整性:违反事务完整性的问题有3类: 脏读 (dirty read)、不可重复读(nonrepeatable read)、幻影行(phantom rows)
解决这3个问题,需要在事务之间使用不同的完整性或者隔离级别。

脏读:一个事务读取了另一个事务尚未提交的更新,就叫做脏读。
例:

set transaction isolation level read committed   --设置事务不允许脏读,可重复读,可幻影行
--transaction 1    打开查询分析器,建立一个连接,运行以下命令
use northwind
begin transaction
update customers
set CompanyName='transaction1'
where CustomerId='ALFKI'

      
commit transaction     --这个命令暂不运行,不让这个事务提交


--transaction 2   在建立一个连接,运行以下命令
use northwind
set transaction isolation level read uncommitted   --设置事务可以脏读
select * from customers
where customerid='ALFKI'

这里能够成功读取到事务1还没有提交更改的数据,此时己经发生了脏读

这里运行以下命令
set transaction isolation level read committed   --设置事务不可以脏读
select * from customers
where customerid='ALFKI'

这时出现延时现象,因为我们设的是不可脏读。 此时将连接1 运行 commit transaction  发现连接2马上显示出了数据。

 


不可重复读:如果事务二能够看到事务一所提交的数据更新,就意味着出了不可重复读型事务缺陷。
例:
在以上建立的连接2中,运行以下命令
--transaction 2
set transaction isolation level repeatable read   --设置事务不可重复读
begin transaction
select * from customers
where customerid='ALFKI'


select * from customers       标注:A
where customerid='ALFKI'
commit transaction

 


在以上建立的连接1中,运行以下命令,发现连接1出现延时现象,说明事务二无法更改同一条数据,在时在连接2中运行标注:A以下的命令,
因为连接1无法更改所以不会出现重复读现象。 标注A:以下命令完成后,连接1更改数据成功。
--transaction 1
begin transaction
update customers
set CompanyName='non-repeatable111'
where CustomerId='ALFKI'
commit transaction

 

幻影行:当一个事务的select语句返回的结果受到另一个事务的影响而发生改变的现象叫做幻影行。
不做测试了。


执行事务的步骤
1.数据库开始状态
2.数据更新命令
3.记录事务日志
4.事务提交
5.更新数据文件
6.事务结束

默认分类 | 阅读 2259 次
文章评论,共0条
游客请输入验证码
浏览15326次
文章分类
最新评论