我使用 Dapper.net 作为 ORM。我有一个名为 BusinessObject 的抽象类,它由代表数据库中表的其他类继承,例如 SubContractorJob。
我在 BusinessObject 类上有一个名为“Persist”的方法,它将记录保存到数据库中:
public abstract class BusinessObject<T>
{
public bool Persist<T>(IDbConnection db, T entity)
where T : BusinessObject<T>, IDBObject
{
if (entity.Id > 0)
{
db.Update(entity);
return true;
}
else
{
db.Insert(entity);
return false;
}
}
}
目前,如您所见,Persist 方法将对象作为输入。
这意味着当我从 BusinessObject 类继承时,我必须从我的子对象中这样调用它:
IDbConnection db = DBConnection.GetConnection();
SubContractorJob s = new SubContractorJob()
{
Id = 3,
SubContractorId = 6,
JobId = 8,
StartDate = DateTime.Today,
EndDate = DateTime.Today.AddDays(10),
EstimatedCost = 20000,
ActualCost = 18000,
IsDeleted = true
};
s.Persist<SubContractorJob>(db, s);
我的问题是:当我已经在 s(子对象)的上下文中调用该方法时,如何在不传递“s”的情况下完成这项工作?
我确实设置了一个接口(IDBObject),因此始终保证子对象具有 Id 字段。
我试过这个:
public bool Persist<T>(IDbConnection db)
where T : BusinessObject<T>, IDBObject
{
if ((typeof(T) as IDBObject).Id > 0)
{
db.Update(this);
return true;
}
else
{
db.Insert(this);
return false;
}
}
但是得到了这个错误:
System.NullReferenceException : Object reference not set to an instance of an object.
谢谢你的帮助!