我有以下类来创建我的 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 类时都会发生这种情况吗?