我是 Entity Framework 的新手,过去我直接使用 Enterprise Library 或 ADO.NET 将模型映射到数据库表。我使用的一种模式是将出现在每个表中的公共审计字段放在基类中,然后为每个对象继承该基类。
我采取两个步骤来保护两个字段(Created、CreatedBy):
- 在基本实体上拥有一个私有的无参数构造函数,并创建第二个需要在创建时传递 Created 和 CreatedBy 的构造函数。
- 将设置器设为私有,以便在创建对象后无法更改值。
基类:
using System;
namespace App.Model
{
[Serializable()]
public abstract class BaseEntity
{
public bool IsActive { get; private set; }
public DateTimeOffset Created { get; private set; }
public string CreatedBy { get; private set; }
public DateTimeOffset LastUpdated { get; protected set; }
public string LastUpdatedBy { get; protected set; }
private BaseEntity() { }
protected BaseEntity(DateTimeOffset created, string createdBy)
{
IsActive = true;
Created = created;
CreatedBy = createdBy;
LastUpdated = created;
LastUpdatedBy = createdBy;
}
}
}
继承类:
using System;
namespace App.Model
{
[Serializable()]
public class Person : BaseEntity
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Email { get; set; }
public Person(DateTimeOffset created, string createdBy) :
base(created, createdBy) { }
}
}
我遇到了两个问题。EF 需要无参数构造函数来创建对象。EF 不会创建具有私有 setter 的数据库列。
我的问题是是否有更好的方法来实现我的 EF 目标:
- 要求在实例化时填充 Created 和 CreatedBy 的值。
- Created 和 CreatedBy 的值不能更改。