首 页 ┆ 源码下载 ┆ IT学院 ┆ 字体下载 ┆ 模板下载 ┆ 源码发布 ┆ 广告合作 ┆ 网站地图 ┆ 虚拟主机 ┆ 中文域名
► 设为首页
► 加入收藏
► 联系我们
源码下载 >> ASP源码 | PHP源码 | ASP.net源码 | JSP源码 | CGI源码 | VC/C++源码 | VB源码 | Delphi源码 | Flash源码
文章学院 >> 网络编程 | 网页设计 | 图形图象 | 数据库 | 服务器 | 网络媒体 | 网络安全 | 操作系统 | 办公软件 | 软件开发 | 黑客知识
字体下载 >> 精制字体 | 非英字体 | 艺术字体 | 著名字体 | 哥特式 | 简单字体 | 手写体 | 节假日 | 图案字体 | 精度像素 | 中文字体
模板下载 >> 企业门户 | 数码网络 | 休闲娱乐 | 影视音乐 | 旅游名胜 | 文化艺术 | 电子商务 | 个性展示 | 登陆导航 | Flash模板
►►您当前的位置:源码园 → IT学院 → 数据库 → SYBASE → 文章内容

SYBASE事务

作者:佚名  来源:不详  发布时间:2007-2-7 11:59:49

事务

  本篇文章描述了数据库事务隔离级对锁的影响,通过对比事务隔离级0和1,理解锁与脏读的关系。

实验内容:分别设置0和1级隔离级,执行两个不同但又有相关的事务。本实验环境如下:

1、  有权访问用户数据库(在此是aca_database)和对数据库表有修改和查询权限。

2、  数据库中有表auths,包含salary列(数据类型是money),有一定数据量(在此有1万行)。

步骤:

1、 如在同一台机器,可分别执行两次“SQL Advantage”,分别用合法帐号登录,准备各自执行一个事务。

2、 在各自界面打开用户数据库aca_database,设置隔离级为1(此亦为缺省值):

set transaction isolation level 1,查看当前隔离级别用select @@isolation

3、 执行第一个事务的前两句,暂不执行后面的提交或回滚。

begin transaction

update auths set salary=salary+100

commit transaction

(rollback transaction)

4、 执行第二个事务 select sum(salary) from auths

5、  第一个事务正常执行结束,但只在内存缓冲区完成修改,事务并没有真正结束,相应也不释放锁,第二个事务处于等待状态。可执行sp_lock和sp_who命令查看。

6、  执行第3步中的提交或回滚命令,第二个事务得到执行。

7、  改变事务隔离级为0,重复执行3-4步。第一个事务没有任何变化,第二个事务很快出来根据第一个事务修改数据而成的结果,似乎在执行响应上并不受第一个事务的影响。

8、  重复第6步结束。

通过上面的实验我们知道:

1、        隔离级0时事务允许脏读,隔离级1时事务不允许脏读,而只是等待前一个修改事务真正结束并释放锁。

2、        隔离级为0时,如果在修改事务的最后是回滚操作,则查询读事务将不能读到正确的数据。

3、        在确信事务中没有回滚操作的可能,并要求更高的执行效率和并行性,只有这时可考虑设置隔离级为0。

  

[] [返回上一页] [打 印]
  • 上一篇文章:数据库日常维护(参考)
  • 下一篇文章:关于SYBASE的自动启动

  • 相关文章:
  • [图文]Sybase数据库技术(10)
  • [图文]Sybase数据库技术(9)
  • [图文]Sybase数据库技术(8)
  • [图文]Sybase数据库技术(7)
  • [图文]Sybase数据库技术(6)
  • [图文]Sybase数据库技术(5)
  • [图文]Sybase数据库技术(4)
  • [图文]Sybase数据库技术(3)
  • [图文]Sybase数据库技术(2)
  • [图文]Sybase数据库(1)
  • [图文]SYBASE dbcc
  • sybase 临时数据库
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 源码发布
Copyright © 2003-2009 Ymyasp.Com. All Rights Reserved .
备案序号:粤ICP备07029071号