所以我正在使用 SQL Compact Edition 之上的实体框架构建一个应用程序。我不喜欢使用实体作为我的业务对象的想法,所以我一直在构建一个层(我称它为 ObjectModel 层,可能不是最好的术语),它将采用我的普通对象,使用它们填充和保存实体。反之亦然 - 获取实体,填充 POCO 以用作业务对象
假设我有一个名为 Customer 的 POCO 对象,
public class Customer:ICustomer
{
#region ICustomer Members
public System.Guid id {get;set;}
public string Forename {get;set;}
public string Surname { get; set; }
#endregion
}
我想使用我的 ObjectModel 层填充它。我目前这样做...
OM_Customer<ICustomer,Entity.Customer> customerLayer = new OM_Agent<ICustomer,Entity.Customer>();
ICustomer businessObject = customerLayer.GetById(new Guid("4a75d5a5-6f5a-464f-b4b3-e7807806f1a9"));
OM_Customer 类继承自 ObjectModelBase,如下所示。
public abstract class ObjectModelBase<BllClass, EntityClass>
{
public DataStoreEntities1 db;
public EntityClass _dataObject;
public string setName;
#region POCO-ORM Mapping Functions
public EntityClass MapBLLToEntity(BllClass bllObject)
{
Mapper.CreateMap<BllClass, EntityClass>();
return Mapper.Map<BllClass, EntityClass>(bllObject);
}
public BllClass MapEntityToBLL(EntityClass entityObject)
{
Mapper.CreateMap<EntityClass, BllClass>();
return Mapper.Map<EntityClass, BllClass>(entityObject);
}
#endregion
public void Save(BllClass toAdd)
{
_dataObject = MapBLLToEntity(toAdd);
using (db = new DataStoreEntities1())
{
db.AddObject(setName, _dataObject);
db.SaveChanges();
}
}
public BllClass GetById(Guid id)
{
using (db = new DataStoreEntities1())
{
EntityClass result = (EntityClass)((object)(from c in db.CustomerSet where c.id == id select c).First());
return MapEntityToBLL(result);
}
}
}
这里的问题在于GetById方法。Save 方法可以被子类很好地使用,因为所有实体框架对象上下文都有 AddObject() 方法。
但是,我希望有一个通用的 getById 方法,因为我所有的实体都有一个名为 id 的属性(在数据库中也是主键)。问题是这里的 linq ......
ModelClass result = (ModelClass)((object)(from c in db.CustomerSet where c.id == id select c).First());
特定于db.CustomerSet。我希望这个抽象类为我的所有实体提供通用的 CRUD/Paging/'Collection Retrieval',但是没有重复的击键,但是,这个简单的 GetById 方法促使我寻求帮助。
目前的想法:
- 让我通过 Id 使用 Entity SQL 来更好地控制构建查询字符串。
- 废弃实体框架和 linq,因为它可能太耗时而无法完全抽象。
将不胜感激任何关于 SO 社区将如何解决上述问题的建议。