随笔 - 435  文章 - 0  评论 - 111  阅读 - 62万 

最初写Nhibernate例子的时候,只考虑了单个方法的事务

    public interface IRepository<T>
    {
        T GetById(
object Id);
        
void Delete(T entity);
        
void Save(T entity);
    }
复制代码
        public void Delete(T entity)
        {
            ISession _session 
= NHelper.GetSession();
            
using (ITransaction tx = _session.BeginTransaction())
            {
                _session.Delete(entity);
                tx.Commit();
            }
 

        }

但是有很多时候,一个事务要跨多个对象的多个方法. 最初的想法是加一个ISession的参数,Delete(T entity,ISession s),

但是这样很丑陋,每个方法都要重写一次,而且和NHibernate绑定的太死了.

看了CodeProject上面一篇文章http://www.codeproject.com/KB/architecture/NHibernateArchitecture.aspx?msg=2185964

用到了SessionManager和TransactionBlock 2个类来包装, 代码变得优雅很多.

根据改文章,做了如下改动:

        public void Delete(T entity)

        {

            ISession _session = NHibernateSessionManager.Instance.GetSession();

            _session.Delete(entity);

            _session.Flush();

        } 

 去掉了Using (ISession xxx) ,因为这样Session才能交给NHibernateSessionManager这个类去管理,而不会Dispose关掉

 另外单个方法里面去掉了ITransaction ,这样事务才能交给TransactionBlock 这个类来接管. 单个方法的提交改用Session.Flush();

 

事务调用的方法,我做了个嵌套事务的单元测试如下:

复制代码
        [Test]
        
public void Test_NestTransaction()
        {
            CompanyRepositoryImp CompanyBO 
= new CompanyRepositoryImp();
            
//只有所有嵌套的事務都成功(成功的标志是手工设置tran.IsValid=true),才提交修改到数据库
            using (TransactionBlock tran = new TransactionBlock())
            {
                Company c 
= new Company();
                c.ID 
= "CO_02";
                c.ModifyDate 
= DateTime.Now;
                c.DefaultCurrency 
= "RMB";
                CompanyBO.Save(c);
                
using (TransactionBlock tran1 = new TransactionBlock())
                {
                    tran1.IsValid 
= false;
                }
                tran.IsValid 
= true;
            }
        }
复制代码

 

 

 

 

复制代码

 

posted on   Gu  阅读(658)  评论(1编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
点击右上角即可分享
微信分享提示