1

我有以下类来创建我的 dbcontext:

public class DataContext : DbContext
{
    public DataContext()
        : base(nameOrConnectionString: "Default") { }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
    }
    public DbSet<TestAccount> TestAccounts { get; set; }
    public DbSet<Application> Applications { get; set; }
}

我的数据库有下表:

CREATE TABLE [dbo].[TestAccount] (
    [TestAccountId]   INT            IDENTITY (1, 1) NOT NULL,
    [ApplicationId] INT,
    [Name] NVARCHAR (MAX) NOT NULL,
    [DataVersion] ROWVERSION,
    CONSTRAINT [PK_dbo.TestAccount] PRIMARY KEY CLUSTERED ([TestAccountId] ASC),
    CONSTRAINT fk_AccountApplication FOREIGN KEY (ApplicationId) REFERENCES Application(ApplicationId)
);

据我了解,EF 将创建数据库的内存模型,但我不明白的是该信息是否会自动包含外键关系,或者我是否需要指定我在 Internet 上找到的类似此示例的那些:

//        public AccountConfiguration()
//        {
//            //            // Account has 1 Speaker, Speaker has many Account records
//            //            HasRequired(s => s.Speaker)
//            //               .WithMany(p => p.SpeakerAccounts)
//            //               .HasForeignKey(s => s.SpeakerId);
//        }

此外,如果数据库已经存在,我是否需要添加必须删除 PluralizingTableNameConvention 之类的内容?

还有一个问题。EF 多久创建一次“数据库的内存模型”。每次我实例化 DbContext 类时都会发生这种情况吗?

4

1 回答 1

2
  1. 是的,除非您遵循约定,否则您需要配置关系。以下 是有关代码优先约定的一些详细信息。

  2. 如果数据库已经存在,您可能需要根据现有数据库更改配置(映射)。

  3. 对于 DbContext 的每个实例,它将创建一个内存实例(但除非您访问它们,否则它不会将数据库中的所有数据加载到内存中)

于 2013-03-05T03:38:04.347 回答