B2B购物网站搭建--后台 1.项目框架_DALFactory数据工厂

项目框架:mvc+EF+Spring.net 三层 搭建

DALFactory:数据工厂

namespace DALFactory
{
/// <summary>
/// 通过反射的形式创建类的实例
/// </summary>
public partial class AbstractFactory
{
private static readonly string AssemblyPath = ConfigurationManager.AppSettings["AssemblyPath"];
private static readonly string NameSpace = ConfigurationManager.AppSettings["NameSpace"];
private static object CreateInstance(string className)
{
var assembly = Assembly.Load(AssemblyPath);
return assembly.CreateInstance(className);
}
}
}

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using DAL;
using IDAL;
namespace DALFactory
{
/// <summary>
/// 数据会话层:就是一个工厂类,负责完成所有数据操作类实例的创建,然后业务层通过数据会话层来获取要操作数据类的实例。所以数据会话层将业务层与数据层解耦。
/// 在数据会话层中提供一个方法:完成所有数据的保存。
/// </summary>
public partial class DBSession : IDBSession
{
public DbContext Db
{
get
{
return DBContextFactory.CreateDbContext();
}
}

/// <summary>
/// 一个业务中经常涉及到对多张操作,我们希望链接一次数据库,完成对张表数据的操作。提高性能。 工作单元模式。
/// </summary>
/// <returns></returns>
public bool SaveChanges()
{
return Db.SaveChanges() > 0;
}

}
}

///////////////////////////////////////////////////////////////////////////////////////////////

using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Remoting.Messaging;
using System.Text;
using System.Threading.Tasks;

namespace DALFactory
{
public class DBSessionFactory
{
public static IDAL.IDBSession CreateDBSession()
{
IDAL.IDBSession DbSession = (IDAL.IDBSession)CallContext.GetData("dbSession");
if (DbSession == null)
{
DbSession = new DALFactory.DBSession();
CallContext.SetData("dbSession", DbSession);
}
return DbSession;
}
}
}

posted @ 2017-03-23 19:47  xiangbudao  阅读(592)  评论(0编辑  收藏  举报