数据库事务
关于事务的隔离性
例如:统计定单系统中事务活动 如下
1.事务T1打印定单表中的记录
2.T2向定单表插入了新的定单,T2提交
3.事务T1统计定单表中的的记录总数,T1提交
因为事务T2在T1结束前向定单表中插入了新的记录,导致事务T1打印的定单记录数量和T1统计的定单数量不一致.
产生并发异常问题的主要原因是并发操作破坏了事务的隔离性,导致数据不一致.如何使一个事务不受到其它事务的干扰,保证数据一致性???
完整的例子代码,在线等待,谢谢大家的关心:)
事务
事务是作为单个逻辑工作单元执行的一系列操作。一个逻辑工作单元必须有四个属性,称为 ACID(原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务:
原子性
事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。
一致性
事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,以保持所有数据的完整性。
事务结束时,所有的内部数据结构(如 B 树索引或双向链表)都必须是正确的。
隔离性
由并发事务所作的修改必须与任何其它并发事务所作的修改隔离。事务查看数据时数据所处的状态,要么是另一并发事务修改它之前的状态,
要么是另一事务修改它之后的状态,事务不会查看中间状态的数据。这称为可串行性,因为它能够重新装载起始数据,并且重播一系列事务,
以使数据结束时的状态与原始事务执行的状态相同。
持久性
事务完成之后,它对于系统的影响是永久性的。该修改即使出现系统故障也将一直保持。
指定和强制事务处理
SQL 程序员要负责启动和结束事务,同时强制保持数据的逻辑一致性。程序员必须定义数据修改的顺序,使数据相对于其组织的业务规则保持
一致。然后,程序员将这些修改语句包括到一个事务中,使 Microsoft® SQL Server™ 能够强制该事务的物理完整性。
企业数据库系统(如 SQL Server)有责任提供一种机制,保证每个事务物理的完整性。SQL Server 提供:
锁定设备,使事务相互隔离。
记录设备,保证事务的持久性。即使服务器硬件、操作系统或 SQL Server 自身出现故障,SQL Server 也可以在重新启动时使用事务日志,
将所有未完成的事务自动地回滚到系统出现故障的位置。
事务管理特性,强制保持事务的原子性和一致性。事务启动之后,就必须成功完成,否则 SQL Server 将撤消该事务启动之后对数据所作的所有修改。
下一篇:数据库架购 >>
相关文章:
- · ADO Data Types与数据库值对应
- · 关于Adodb.Stream 的使用说明
- · 使用 Microsoft SQL Server 2000 的全文搜索功能构建 Web 搜索应用程序
- · 如何在SQL中启用全文检索功能?(实例)
- · 防止IIS返回错误信息泄露服务器敏感信息
- · SQL查询语句精华使用简要
- · 面试时最经常被问到的问题(Frenquently asked interview questions)之 Databases 篇
- · 面向对象数据库的正确评价与选择
- · 重建 SQL Server 系统数据库!
- · SQL Server连接失败错误及解决
- · SET NOCOUNT 的用法
- · SET XACT_ABORT 的用法
- · 将小写金额转换为英文大写的SQL函数
- · 将小写金额转换为中文大写的SQL函数
- · 用 INNER JOIN语法联接多个表建记录集
- · 剪切板上文本数据的传送
- · 创建自定义模板 Building Custom Templates
- · [收藏]五种提高 SQL 性能的方法
- · [收藏]使用Reporting Services中的窗体身份验证
- · [收藏]利用SQL Server Reporting Services 从应用程序生成用户友好的报表
- · Processing Sequentially Through a Set of Records
- · Building a T-SQL Loop
- · Statspack之初体验
- · --竖表变行表
- · 关于scn的理解
- · 如何将数据表导出备份到excel表格
- · 为什么用ROUND四舍五入总是无法得到正确数值?
- · Wml的标准函数库
- · 十进制转换成二进制(如8转成1000)
- · 最有效率的“多字段模糊匹配关键字查询”的解决办法
- · TOM在线与Skype联手推出"Tom-Skype"
- · Windows下看线程
- · Mysl 4.0 RPM 安装 及相关操作
- · 程序: 使用 API 开始屏幕保护
- · Win2000常用端口列表
- · SQL 中自己创建函数,分割字符串
- · ERP与数据库
- · 创建实体化视图的几个注意点
