我有两个解决方案,使用EF 6.0和两个使用完全相同的默认配置。不过,他们连接到2个不同的数据源!? (localdb)\ mssqllocaldb和。\ SQLEXPRESS。为什么我的项目连接到不同的数据源?
我的配置:
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="mssqllocaldb" />
</parameters>
</defaultConnectionFactory>
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
的的DbContext也是既相似:
public class PlusUltraContext : DbContext
{
public PlusUltraContext() : base("PlusUltra")
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
base.OnModelCreating(modelBuilder);
}
public DbSet<Models.Article> Articles { get; set; }
public DbSet<Models.ArticleComment> Comments { get; set; }
}
VS
public class InvoicingContext : DbContext
{
public DbSet<Address> Addresses { get; set; }
public DbSet<Company> Companies { get; set; }
public DbSet<Country> Countries { get; set; }
public DbSet<Currency> Currencies { get; set; }
public DbSet<Invoice> Invoices { get; set; }
public DbSet<InvoiceLine> InvoiceLines { get; set; }
public DbSet<Person> Persons { get; set; }
public DbSet<Unit> Units { get; set; }
public InvoicingContext() : base("Invoicing")
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
base.OnModelCreating(modelBuilder);
}
}
然而,当我运行Update-数据库命令,第一个项目连接到\ SQLEXPRESS,而其他所连接到(的LocalDB)\ mssqllocaldb
目标数据库是: 'PlusUltra'(数据源:(的LocalDB)\ mssqllocaldb,提供者:System.Data.SqlClient的,起源:公约)。
VS
目标数据库是: '发票'(数据源:\ SQLEXPRESS,提供者:System.Data.SqlClient的,产地:公约)。
我的问题
什么是有些事情我可以检查看看他们为什么不同的表现?