事务(TRANSACTION)是作为单个逻辑工作单元执行的一系列操作
这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行
事务是一个不可分割的工作逻辑单元
----------------------------------------------
例如
转帐过程就是一个事务。
它需要两条UPDATE语句来完成,这两条语句是一个整体,如果其中任一条出现错误,则整个转帐业务也应取消,两个帐户中的余额应恢复到原来的数据,从而确保转帐前和转帐后的余额不变,即都是1001元。
--------------------------------------------
事务必须具备以下四个属性,简称ACID属性
原子性(Atomicity):事务是一个完整的操作。事务的各步操作是不可分的(原子的);要么都执行,要么都不执行
一致性(Consistency):当事务完成时,数据必须处于一致状态
隔离性(Isolation):对数据进行修改的所有并发事务是彼此隔离的,这表明事务必须是独立的,它不应以任何方式依赖于或影响其他事务
永久性(Durability):事务完成后,它对数据库的修改被永久保持,事务日志能够保持事务的永久性
------------------------------------------------
如何创建事务
T-SQL使用下列语句来管理事务:
开始事务:BEGIN TRANSACTION
提交事务:COMMIT TRANSACTION
回滚(撤销)事务:ROLLBACK TRANSACTION
一旦事务提交或回滚,则事务结束。
判断某条语句执行是否出错:
使用全局变量@@ERROR;
@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
如: SET @errorSum=@errorSum+@@error
了解事务的分类:
显示事务:用BEGIN TRANSACTION明确指定事务的开始,这是最常用的事务类型
隐性事务:通过设置SET IMPLICIT_TRANSACTIONS ON 语句,将隐性事务模式设置为打开,下一个语句自动启动一个新事务。当该事务完成时,再下一个 T-SQL 语句又将启动一个新事务
自动提交事务:这是 SQL Server 的默认模式,它将每条单独的 T-SQL 语句视为一个事务,如果成功执行,则自动提交;如果错误,则自动回滚
使用事务解决银行转帐问题
……关键语句讲解………
BEGIN TRANSACTION
/*--定义变量,用于累计事务执行过程中的错误--*/
DECLARE @errorSum INT
SET @errorSum=0 --初始化为0,即无错误
/*--转帐:张三的帐户少1000元,李四的帐户多1000元*/
UPDATE bank SET currentMoney=currentMoney-1000
WHERE customerName='张三'
SET @errorSum=@errorSum+@@error
UPDATE bank SET currentMoney=currentMoney+1000
WHERE customerName='李四'
SET @errorSum=@errorSum+@@error --累计是否有错误
IF @errorSum<>0 --如果有错误
BEGIN
print '交易失败,回滚事务'
ROLLBACK TRANSACTION
END
ELSE
BEGIN
print '交易成功,提交事务,写入硬盘,永久的保存'
COMMIT TRANSACTION
END
GO
print '查看转帐事务后的余额'
SELECT * FROM bank
GO
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/meng1986/archive/2007/08/01/1720492.aspx
分享到:
相关推荐
如果当前不存在事务,则会创建一个新的事务,并在该事务中运行当前方法。这种方式非常适合于那些可能在事务上下文中运行的方法。 - **PROPAGATION_SUPPORTS**:此行为表示如果当前存在事务,则在该事务中运行当前...
- **Required New**:总是创建新的事务,如果已有事务,会挂起当前事务。 - **Mandatory**:必须存在事务,否则抛出异常。 - **Never**:不应存在事务,如果已有事务,也会抛出异常。 了解这些事务管理机制对于编写...
如果当前没有事务,则创建一个新的事务。 - **应用场景**:这是最常用的一种事务传播特性,适用于大部分情况下的业务逻辑。 - **示例**:假设有一个`Transaction1`事务,在该事务内的另一个方法调用(如`...
### Spring事务的传播特性和隔离级别 #### 一、事务的基本概念 在计算机科学中,事务(transaction)是指一系列操作的集合,这些操作要么全部成功完成,要么全部失败回滚,确保数据的一致性和完整性。事务具备四个...
如果是独立调用,则将启动自己的事务。 2. **PROPAGATION_SUPPORTS** - 如果当前存在事务,则支持并参与该事务;如果没有,则以非事务的方式执行。这适用于那些在事务内或事务外都可以正常工作的操作。 3. **...
4. **PROPAGATION_REQUIRES_NEW**:总是创建一个新的事务,如果当前存在事务,先挂起当前事务。 5. **PROPAGATION_NOT_SUPPORTED**:总是运行在非事务上下文中,如果当前存在事务,就挂起该事务。 6. **...
这四个特性——原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)——合称为ACID属性,是事务的核心特征。 原子性保证了事务中的每个操作都是不可分割的,即使在系统故障或...
在Spring框架中,事务管理是核心特性之一,它允许开发者以声明式或编程式的方式处理应用中的事务。Spring事务管理的目的是确保数据的一致性和完整性,尤其是在多操作、多资源的环境中。本Demo将深入探讨Spring如何...
7. **PROPAGATION_NESTED**:如果当前存在事务,则创建一个嵌套事务;如果当前没有事务,则行为类似于`PROPAGATION_REQUIRED`。 #### 三、具体示例 为了更好地理解这七种传播行为,我们可以通过具体的示例来进行...
在场景二中,如果`AccountServiceImpl`的方法标记为`REQUIRED`,并且被一个没有事务的方法调用,那么Spring会创建一个新的事务来执行这个方法。因此,users和accounts都会执行相应的操作。 2. **Propagation_...
本文将深入探讨C#语言中与数据库事务相关的原理及实践,包括事务的定义、特性、类型,以及如何在C#中利用Entity Framework(EF)进行事务开发和管理。 首先,我们需要理解什么是事务。在数据库系统中,事务是一组...
- 如果商品不存在,创建新的库存记录,并根据商品预警数量(WaringNum)进行处理。 3. **错误检查**:在执行每个操作后,检查是否产生错误。如果发生错误,可以通过`@@ERROR`系统变量获取错误号。例如: ```sql ...
在理解分布式事务之前,我们首先需要了解数据库事务的基本属性,即ACID特性。 - **原子性(Atomicity)**:事务中的所有操作要么全部成功,要么全部失败。如果其中任何一部分失败,则整个事务都会被撤销,并且回滚...
如果不存在,则创建一个新的事务。这也是最常用的模式。 2. **PROPAGATION_SUPPORTS**:如果当前存在事务,那么运行在该事务内;如果没有事务,则以非事务方式执行。 3. **PROPAGATION_MANDATORY**:如果当前存在...
Spring AOP 提供了一种灵活的方式来实现事务管理,通过配置事务特性和事务管理切面来实现事务管理。 配置事务管理切面: 在 Spring AOP 中,事务管理切面是通过 `<aop:config>` 元素来配置的。该元素用于定义一个...
如果启用事务操作,我们将创建一个 `SQLiteTransaction` 对象,并将其与 `SQLiteConnection` 对象关联起来。 使用事务操作 使用事务操作可以确保数据库的数据一致性和完整性。下面是一个简单的示例代码: ```...
声明式事务管理则依赖于AOP(面向切面编程)来自动处理事务的开始、提交或回滚,无需开发者编写事务相关的代码。 Spring事务管理的核心组件包括: 1. **TransactionDefinition**: 定义了事务的属性,如隔离级别、...
事务的四大特性,即ACID(原子性、一致性、隔离性和持久性),是数据库系统的核心原则。 1. **原子性(Atomicity)**:事务中的每个操作要么全部完成,要么全部不完成,不存在部分完成的情况。如果在事务执行过程中...
事务日志的回滚机制允许撤销未完成的事务,而其持久性特性确保已提交的事务即使在系统崩溃后也能保留其状态。通过读取日志记录,数据库可以从特定的LSN点向前或向后恢复,实现数据的一致性。 了解事务日志的工作...
例如,PROPAGATION_REQUIRED表示如果当前存在事务,则加入到当前事务,如果当前没有事务,则创建一个新的事务。其他的传播特性还包括PROPAGATION_SUPPORTS、PROPAGATION_MANDATORY、PROPAGATION_REQUIRES_NEW、...