CZBK.ItcastOA.DALFactory.DBSession.cs

using CZBK.ItcastOA.DAL;
using CZBK.ItcastOA.IDAL;
using CZBK.ItcastOA.Model;
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;
namespace CZBK.ItcastOA.DALFactory
{
    /// <summary>
    /// 数据会话层:就是一个工厂类,负责完成所有数据操作类实例的创建,然后业务层通过数据会话层来获取要操作数据类的实例。所以数据会话层将业务层与数据层解耦。
    /// 在数据会话层中提供一个方法:完成所有数据的保存。
    /// </summary>
    public partial class DBSession : IDBSession
    {
      // OAEntities Db = new OAEntities();
       public DbContext Db
       {
           get
           {
               return DBContextFactory.CreateDbContext(); 
           }
       }
       //private IUserInfoDal _UserInfoDal;
       //public IUserInfoDal UserInfoDal
       //{
       //    get {
       //        if (_UserInfoDal == null)
       //        {
       //            //_UserInfoDal = new UserInfoDal();
       //            _UserInfoDal = AbstractFactory.CreateUserInfoDal();//通过抽象工厂封装了类的实例的创建
       //        }
       //        return _UserInfoDal;
       //    }
       //    set
       //    {
       //        _UserInfoDal = value;
       //    }
       //}
       /// <summary>
       /// 一个业务中经常涉及到对多张操作,我们希望链接一次数据库,完成对张表数据的操作。提高性能。 工作单元模式。
       /// </summary>
       /// <returns></returns>
       public bool SaveChanges()
       {
           return Db.SaveChanges() > 0;
       }
       public int ExecuteSql(string sql, params SqlParameter[] pars)
       {
          return Db.Database.ExecuteSqlCommand(sql,pars);
       }
       public List<T> ExecuteQuery<T>(string sql, params SqlParameter[] pars)
       {
           return Db.Database.SqlQuery<T>(sql,pars).ToList();
       }

    }
}
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值