在一个事务里面调用存储过程。使用了三种方法编写事务,下面的一)和二)都不能回滚存储过程,只能回滚存储过程外的sql数据库操作。第三种方法才能回滚存储过程。
一)
@Transactional
二)org.springframework.transaction.support.TransactionTemplate
java代码
public void savePurchaseOrder(final PurchaseOrder purchaseOrder,final long changerId) {
transactionTemplate.execute(new TransactionCallback() {
public Object doInTransaction(TransactionStatus ts)
{
try{
long identity0=0;//父级id
identity0=savePurchaseOrderSummary(purchaseOrder, changerId);
for(int i=0;i<purchaseOrder.getPurchaseOrder_material_list().size();i++){
long identity1=0;//父级id
PurchaseOrder_material purchaseOrder_material=purchaseOrder.getPurchaseOrder_material_list().get(i);
identity1=savePurchaseOrderMaterial(purchaseOrder_material,identity0);
for(int j=0;j<purchaseOrder_material.getPurchaseOrder_material_colorNo_list().size();j++){
long identity2=0;//父级id
PurchaseOrder_material_colorNo purchaseOrder_material_colorNo=purchaseOrder_material.getPurchaseOrder_material_colorNo_list().get(j);
identity2=savePurchaseOrderMaterialColorNo(purchaseOrder_material_colorNo,identity1);
for(int k=0;k<purchaseOrder_material_colorNo.getPurchaseOrder_material_colorNo_yarnCount_list().size();k++){
long identity3=0;
PurchaseOrder_material_colorNo_yarnCount purchaseOrder_material_colorNo_yarnCount=purchaseOrder_material_colorNo.getPurchaseOrder_material_colorNo_yarnCount_list().get(k);
identity3=savePurchaseOrderMaterialColorNoYarnCount(purchaseOrder_material_colorNo_yarnCount,identity2);
//此处不做循环,不需要有返回值identity,可使用预处理
savePurchaseOrderMaterialColorNoYarnCountClNoOrYrNoList(purchaseOrder_material_colorNo_yarnCount.getPurchaseOrder_material_colorNo_yarnCount_clNoOrYrNo_list());
}
}
}
}catch(Exception e){
ts.setRollbackOnly();
}
return null;
}
});
}
xml配置:
<bean id="yarnSpinningScheduleService" class="com.jjfz.fasys.service.impl.YarnSpinningScheduleServiceImpl">
<property name="dao" ref="dao"/>
<property name="transactionTemplate">
<bean class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager" ref="transactionManager"/>
</bean>
</property>
</bean>
三)确保每个调用的Connection con是同一个,发生错误时,回滚。
@Transactional//必须有这句,下面才能回滚
public void savePurchaseOrder(final PurchaseOrder purchaseOrder,final long changerId) {
dao.getJdbcTemplate().execute(new ConnectionCallback() {
public Object doInConnection(Connection con)
{
try{
long identity0=0;//父级id
identity0=savePurchaseOrderSummary(con,purchaseOrder, changerId);
for(int i=0;i<purchaseOrder.getPurchaseOrder_material_list().size();i++){
long identity1=0;//父级id
PurchaseOrder_material purchaseOrder_material=purchaseOrder.getPurchaseOrder_material_list().get(i);
identity1=savePurchaseOrderMaterial(con,purchaseOrder_material,identity0);
for(int j=0;j<purchaseOrder_material.getPurchaseOrder_material_colorNo_list().size();j++){
long identity2=0;//父级id
PurchaseOrder_material_colorNo purchaseOrder_material_colorNo=purchaseOrder_material.getPurchaseOrder_material_colorNo_list().get(j);
identity2=savePurchaseOrderMaterialColorNo(purchaseOrder_material_colorNo,identity1);
for(int k=0;k<purchaseOrder_material_colorNo.getPurchaseOrder_material_colorNo_yarnCount_list().size();k++){
long identity3=0;
PurchaseOrder_material_colorNo_yarnCount purchaseOrder_material_colorNo_yarnCount=purchaseOrder_material_colorNo.getPurchaseOrder_material_colorNo_yarnCount_list().get(k);
identity3=savePurchaseOrderMaterialColorNoYarnCount(purchaseOrder_material_colorNo_yarnCount,identity2);
//此处不做循环,不需要有返回值identity,可使用预处理
savePurchaseOrderMaterialColorNoYarnCountClNoOrYrNoList(purchaseOrder_material_colorNo_yarnCount.getPurchaseOrder_material_colorNo_yarnCount_clNoOrYrNo_list());
}
}
}
}catch(Exception e){
try {
con.rollback();
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
return null;
}
});
}
分享到:
相关推荐
在Oracle数据库环境中,事务管理与存储过程的结合是实现数据一致性、事务回滚以及错误处理的关键技术之一。本文将深入探讨“Oracle事务回滚存储过程”这一主题,旨在理解其核心概念、工作原理以及实际应用。 ### ...
2. **事务恢复**:如果在事务处理过程中发生例程失败,Oracle会在下次打开数据库时利用重做日志文件中的回滚段信息来恢复未提交的数据。 3. **读一致性**:回滚段确保了在并发环境中,不同的会话看到的数据是一致的...
3. 读一致性:Oracle通过回滚段确保在事务执行过程中,其他会话看不到未提交的修改,保证了数据的一致性视图。 回滚段的种类: 1. 系统回滚段:自动创建,仅用于系统表空间内的对象。 2. 非系统回滚段:分为私有和...
在Oracle数据库管理中,回滚段(Rollback Segment)是一个重要的组成部分,主要用于存储事务处理的回滚信息。当系统遇到回滚段灾难,如回滚段损坏或异常,导致数据库无法正常启动时,进行有效的灾难恢复是至关重要的...
在Oracle数据库中,**回滚段(Rollback Segment)**是一种特殊类型的段,用于存储事务处理过程中更改的数据的旧值。这些数据在事务处理期间被存储起来,以便在需要时能够恢复到更改之前的状态。当一个事务提交或回滚...
此外,在事务处理过程中如果遇到实例失败(例如服务器故障),回滚段中记录的信息会被保存在重做日志文件中。在数据库重启时,系统会利用这部分信息来进行未提交数据的恢复,确保数据的一致性和完整性。 #### 读...
例如,在银行转账中,如果转账过程中出现问题,系统可以利用回滚组件撤销转账操作,保证资金安全。 五、技术挑战与优化 虽然数据回滚组件提供了强大的数据保护,但它也面临着一些挑战,如日志管理的复杂性、性能...
在Oracle数据库管理中,回滚日志(Rollback Segment)是用于存储事务处理过程中更改前的数据副本的关键组件,以便在需要时可以恢复到事务开始前的状态。然而,随着时间的推移,这些日志文件可能会积累大量的数据,...
为了提高效率,可以使用SQL批量插入语句或存储过程。在导入过程中,如果遇到错误,事务会捕获异常并决定是否回滚。 5. **错误处理与日志记录**:为了解决导入过程中可能出现的问题,需要记录详细的日志,包括成功...
总结来说,SQL2000中的事务回滚问题关键在于理解和有效利用`SET XACT_ABORT`选项来控制错误处理策略,以及在错误发生时及时回滚事务并提供适当的错误反馈。在编写涉及事务处理的存储过程或脚本时,确保正确处理错误...
DB2支持存储过程的版本控制,允许你创建、替换和回滚到先前的版本,确保代码的稳定性和可维护性。 通过深入学习和实践上述知识点,你可以成为一名熟练的DB2存储过程开发者,能够创建高效、可靠的数据库解决方案。在...
Struts 是一个经典的Java Web开发框架,由Apache...总结,通过Struts框架实现文件归档及回滚,需要结合文件操作、版本控制、数据库存储等多方面的技术。理解并熟练运用这些技术,可以构建出健壮且功能完善的Web应用。
在存储过程生成器中集成回滚功能,意味着用户在创建或修改存储过程时,如果操作失败,系统可以自动撤销这些改变,保护了数据库的稳定性。 导出功能则是为了方便数据备份和迁移。用户可以利用此工具快速导出已生成的...
在游戏开发中,Unity3D 是一款非常流行的跨平台3D引擎,它为开发者提供了强大的工具来构建高质量的游戏。...在实际开发过程中,还需考虑性能、内存使用以及用户体验等方面的细节,确保回滚操作既实用又高效。
- 远程存储过程不受事务控制,更改无法回滚。 - 单个存储过程支持最多2100个参数。 - 局部变量的数量受可用内存限制。 - 存储过程最大可达128MB,取决于内存情况。 #### 名称限定 在存储过程中,如果对象名未明确...
如果过程中发生错误,可以通过回滚事务来恢复到操作前的状态。 3. **更新状态**:更新pubkjqj表中的jzbz和syzt字段,将结账标志设置为1,表示当前会计期已进入结账阶段。 4. **判断与处理**:当@ikjqj等于12(通常...
在数据库管理中,存储过程是一种预编译的SQL语句集合,它封装了特定的数据库操作,便于重复使用和提高性能。在这个场景中,我们关注的是一个名为"银行转账存储过程"的特定应用,它是针对银行转账业务逻辑的实现。这...
在SQL Server中,还可以使用存储过程进行事务管理,确保一组数据库操作要么全部成功,要么全部回滚,这对于保持数据一致性至关重要。此外,存储过程支持嵌套,即在一个存储过程中调用另一个存储过程,这在处理复杂...
在数据库管理中,存储过程(Stored Procedure)是一种预编译的SQL代码集合,可以在数据库服务器上执行,以完成特定的任务,比如数据的增删改查。在本例中,我们关注的是如何在C#中调用一个存储过程来实现图书的删除...
当一个事务在执行过程中遇到问题,例如系统故障或用户请求回滚,数据库系统需要有能力恢复到事务开始前的状态。这就引出了我们今天要探讨的核心概念——undo log,即回滚日志。 Undo log是数据库管理系统用来记录...