以下是我的数据库表的一个片段:
帐户
--------------------------
ACCOUNT_ID
Account_Types
CUSTOMER_ID
Row_Guid
客户
--------------------------
CUSTOMER_ID
将First_Name
姓氏
平衡
Row_Guid
订单
--------------------------
ORDER_ID
CUSTOMER_ID
Row_Guid
我使用Entity Framework生成了类。之后,我开始在业务逻辑层中编写一个实用程序类,它将与表示层进行通信以执行添加删除等。例如,当用户单击表单中的“添加”按钮时,事件将从此调用方法实用班。
由于所有表的功能都相似,但我可以创建一个通用接口,然后让每个Table特定的实用程序类实现它。
我有以下内容:
BillingDBEntities
是实体框架生成的类,它包含所有“域对象”。此类具有内部对象,例如:ACCOUNT,CUSTOMER,..表示数据库表。
这是我的实用程序界面:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Objects.DataClasses;
using DataAccessLayer;
namespace BusinessLogicLayer.Implementations
{
public interface IUtility<T> where T : EntityObject
{
void AddEntity(BillingDBEntities billingEntity, T item);
void AddEntity(BillingDBEntities billingEntity, object[] items, Type[] types);
void RemoveEntity(BillingDBEntities billingEntity, T item);
void RemoveEntity(BillingDBEntities billingEntity, object[] items, Type[] types);
void UpdateEntity(BillingDBEntities billingEntity, object[] items, Type[] types);
}
}
对于像void AddEntity(BillingDBEntities billingEntity, T item);
这样的方法,T将简单地替换为ACCOUNT,ORDER,CUSTOMER等。但是对于像void这样的方法
AddEntity(BillingDBEntities billingEntity, object[] items, Type[] types);
items数组包含该类型的组件。对于Account,它将包含(Account_id,Customer_id,Account_type,Row_guid),types数组包含组件的类型,例如它的帐户(长,长,长,Guid)。
public class Utility : IUtility<ACCOUNT>
{
public void AddEntity(BillingDBEntities billingEntity, ACCOUNT item)
{
billingEntity.ACCOUNTS.AddObject(item);
}
public void AddEntity(BillingDBEntities billingEntity, object[] items, Type[] types)
{
//What should I write here????
}
..
.
.
.
}
问题:如何实施该方法?如何在方法内调用BillingDBEntities
来设置对象变量?有没有办法,而不是创建Utility,Utility,...我只能创建一个类?
如果我的界面设计错误或者有众所周知的方法来执行此类任务,请告诉我。
提前谢谢