我有一个项目有很多数据结构,我想在其中引入一个数据库。我正在研究实体框架CTP5的代码优先功能。
现在,我为每种类型使用不同的标识符类型(例如TypeAIdentifier,TypeBIdentifier等)。这很好,因为它在使用这些标识符时允许类型安全。问题是我似乎无法让EF使用非基本类型作为标识符。 http://blogs.msdn.com/b/efdesign/archive/2010/03/30/data-annotations-in-the-entity-framework-and-code-first.aspx中有一个提示:
KeyAttribute
KeyAttribute is used to specify that a property/column is part of the primary
key of the entity and applies to scalar properties only.
确实,以下程序会引发异常:
class Program
{
static void Main(string[] args)
{
MyDb db = new MyDb();
db.SaveChanges();
}
}
class MyDb : DbContext
{
public DbSet<MyObject> MyObjects { get; set; }
}
class MyObject
{
[Key] public MyIdentifierType MyId { get; set; }
public int IntValue { get; set; }
}
class MyIdentifierType
{
public int UniqueId { get; set; }
}
奇怪的是,这个程序抛出了一个MissingMethodException(“没有为此对象定义的无参数构造函数”),但我确信这与KeyAttribute有关,因为以下任何一个都会使程序运行:
如何让EF将我的标识符类映射为PK?想到两个选项:
有没有办法实现这个目标?
答案 0 :(得分:0)
我将带有属性的密钥转换为自定义类型。
public class MyObject
{
public int Id { get; set; }
public int IntValue { get; set; }
public MyIdentifierType MyId
{
get { return new MyIdentifierType {UniqueId = Id}; }
set { Id = value.UniqueId; }
}
}