zoukankan      html  css  js  c++  java
  • MVC+LINQToSQL的Repository模式之(二)数据基类

    namespace Data.TEST
    {
        /// <summary>
        /// 数据操作基类
        /// </summary>
        public abstract class TESTRepositoryBase
        {
            /// <summary>
            /// 数据库基类
            /// </summary>
            protected Entity.TEST.LinqTESTDataContext _db = (Entity.TEST.LinqTESTDataContext)DbFactory.Intance("TEST", System.Threading.Thread.CurrentThread);
            /// <summary>
            /// 统一提交动作
            /// </summary>
            protected virtual void SubmitChanges()
            {
                ChangeSet cSet = _db.GetChangeSet();
                if (cSet.Inserts.Count > 0
                    || cSet.Updates.Count > 0
                    || cSet.Deletes.Count > 0)
                {
                    try
                    {
                        _db.SubmitChanges(System.Data.Linq.ConflictMode.ContinueOnConflict);
                    }
                    catch (System.Data.Linq.ChangeConflictException ex)
                    {
                        foreach (System.Data.Linq.ObjectChangeConflict occ in _db.ChangeConflicts)
                        {
                            // 使用当前数据库中的值,覆盖Linq缓存中实体对象的值 
                            occ.Resolve(System.Data.Linq.RefreshMode.OverwriteCurrentValues);
                            // 使用Linq缓存中实体对象的值,覆盖当前数据库中的值 
                            occ.Resolve(System.Data.Linq.RefreshMode.KeepCurrentValues);
                            // 只更新实体对象中改变的字段的值,其他的保留不变 
                            occ.Resolve(System.Data.Linq.RefreshMode.KeepChanges);
                        }
                        _db.SubmitChanges();
                    }
                }
            }
        }
    }

  • 相关阅读:
    三层架构
    SQL数据库资料整理(2006年)
    SQL基础:常用SQL语句详解(转)
    什么是SOA?
    DOTNET中的SqlHelper类
    C#精髓(WMI完美秀出CPU编号厂商主频电压等全部信息)
    根据分类,每类随机抽取N个(N对每个分类都不一样,SQL问题)
    C#,你真的入门了吗
    .Net平台开发的技术规范与实践精华总结 (转)
    学习Java需要达到的30个目标
  • 原文地址:https://www.cnblogs.com/lori/p/2241026.html
Copyright © 2011-2022 走看看