首页 技术 正文
技术 2022年11月15日
0 收藏 748 点赞 3,413 浏览 2785 个字

在实际项目中用了Spring.Net框架之后,发现这框架在处理数据库事务上特别强大,声明式的数据库事务解放了一般开发人员对数据库事务操作的复杂处理。尤其是多数据库事务处理上,尤为显得更简便,几个简单的配置就能搞定。本篇文章对于如何用Spring.Net 2.0 + MVC 5.0搭建开发项目,就不再多赘述。直接上关键事务配置文件的代码:

  1. <?xml version=”1.0″ encoding=”utf-8″ ?>
  2. <objects
    xmlns=”http://www.springframework.net”
    xmlns:db=”http://www.springframework.net/database”
    xmlns:tx=”http://www.springframework.net/tx”>
  3.   <description></description>
  4.   <!–数据库提供者–>
  5.   <db:provider
    id=”BaseDbProvider”
    provider=”System.Data.SqlClient”
    connectionString=”Data Source=YOOBABY-ZXRJ\ZXSOFT;User ID=sa;Password=123456;database=SYPT;”/>
  6.   <db:provider
    id=”BakDbProvider”
    provider=”System.Data.SqlClient”
    connectionString=”Data Source=YOOBABY-ZXRJ\ZXSOFT;User ID=sa;Password=123456;database=XNZH;”/>
  7.  
  8.  
  9.   <!–基础数据库 AdoTemplate访问上下文–>
  10.   <object
    id=”BaseDb”
    type=”Spring.Data.Generic.AdoTemplate, Spring.Data”>
  11.     <property
    name=”DbProvider”
    ref=”BaseDbProvider”/>
  12.     <property
    name=”DataReaderWrapperType”
    value=”Spring.Data.Support.NullMappingDataReader, Spring.Data”/>
  13.   </object>
  14.  
  15.   <!–备份数据库 AdoTemplate访问上下文–>
  16.   <object
    id=”BakDb”
    type=”Spring.Data.Generic.AdoTemplate, Spring.Data”>
  17.     <property
    name=”DbProvider”
    ref=”BakDbProvider”/>
  18.     <property
    name=”DataReaderWrapperType”
    value=”Spring.Data.Support.NullMappingDataReader, Spring.Data”/>
  19.   </object>
  20.  
  21.   <!–数据事务 ADO.NET Transaction Config–>
  22.   <object
    id=”TransactionManager”
    type=”Spring.Data.Core.AdoPlatformTransactionManager, Spring.Data”>
  23.     <property
    name=”DbProvider”
    ref=”BaseDbProvider”/>
  24.   </object>
  25.  
  26.   <object
    id=”TransactionManager2″
    type=”Spring.Data.Core.AdoPlatformTransactionManager, Spring.Data”>
  27.     <property
    name=”DbProvider”
    ref=”BakDbProvider”/>
  28.   </object>
  29.  
  30.   <tx:attribute-driven
    transaction-manager=”TransactionManager”/>
  31.   <tx:attribute-driven
    transaction-manager=”TransactionManager2″/>
  32. </objects>

如上数据事务配置文件中,定义了两个DbProvider , 两个AdoTempalate上下文,并正对两个DbProvider 都定义了数据事务.

dao层配置了相应代码:

  1. <!–数据操作 dao config –>
  2. <object
    id=”Dao.User”
    type=”HH.Application.Core.Dao.Impl.UserDao, HH.Application.Core”>
  3.   <property
    name=”AdoTemplate”
    ref=”BaseDb”/>
  4. </object>
  5.  
  6. <object
    id=”Dao.Role”
    type=”HH.Application.Core.Dao.Impl.RoleDao, HH.Application.Core”>
  7.   <property
    name=”AdoTemplate”
    ref=”BakDb”/>
  8. </object>

UserDao的AdoTemplate属性注入的是BaseDb实例, RoleDao的AdoTemplate属性注入的是BakDb实例.

在server层会去调用不同的dao对象去操作数据库

  1. [Transaction]
  2. public
    void TestTransaction()
  3. {
  4.     var model = new User();
  5.     model.UserName = “xioliu”;
  6.     model.Password = “”;
  7.     model.OwnerCode = “”;
  8.     model.OwnerName = “”;
  9.     UserDao.Insert(model);
  10.  
  11.     Role rmodel = new Role();
  12.     rmodel.RoleName = “测试员”;
  13.     rmodel.IsSys = 1;
  14.     RoleDao.Insert(rmodel);
  15. }

正常的测试结果,是可以往两个数据库不同表添加数据的。

先来看异常测试,在代码中抛出异常,如下图所示

Spring.Net实现跨数据库服务层事务管理

 

调用webapi测试结果,如图所示:

Spring.Net实现跨数据库服务层事务管理

查询数据库,发现 数据确实没有添加成功

Spring.Net实现跨数据库服务层事务管理

现在去除代码中的抛出异常代码,再进行测试,返回了执行成功信息

Spring.Net实现跨数据库服务层事务管理

查看数据库,表中,也发现,数据正常添加到了两个表中。

Spring.Net实现跨数据库服务层事务管理

说明,Spring.Net配置的两个事务确实都已生效。 在实际测试中,我有去除代码函数TestTransaction头部的【Transaction】注解属性,再在函数中最后抛出异常,测试结果是两条数据都成功添加到了数据表中。

不得不说,Spring.Net的跨数据库事务实现,确实太强大了. 只需要简单的配置就可以.

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,494
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,295