如何将ASP.NET MVC 3的EF代码优先模式禁用并改写为长尾词?

2026-03-30 12:501阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计426个文字,预计阅读时间需要2分钟。

如何将ASP.NET MVC 3的EF代码优先模式禁用并改写为长尾词?

在开发ASP.NET MVC3音乐商店教程时,若未连接到附加的数据库EF,而是正在SQL EXPRESS中创建新数据库(代码优先),如何避免这种情况发生?

应使用EF的配置来连接到现有数据库,而不是创建新数据库。具体操作是:连接字符串应指向现有数据库,而不是指示创建新数据库。这样配置后,EF会连接到现有数据库,而不是尝试创建一个新的。

我正在做ASP .NET MVC3音乐商店教程而不是连接到附加数据库EF正在SQLEXPRESS中创建一个新数据库(代码优先).如何防止这种情况发生.使用EF的配置应该连接到现有数据库 – 而不是创建新数据库.
我有一个DbContext类,如下所示

using System.Data.Entity; namespace MusicStore.Models { public class MusicStoreEntities:DbContext { public DbSet<Album> Albums { get; set; } public DbSet<Genre> Genres { get; set; } } }

我的web.config有以下连接字符串

<connectionStrings> <add name="MusicStoreEntities" connectionString="data source=.\SQLEXPRESS; Integrated Security=SSPI; AttachDBFilename=|DataDirectory|\MvcMusicStore.mdf; User Instance=true" providerName="System.Data.SqlClient" /> </connectionStrings> 在Application_Start()中,将数据库初始化策略设置为:

DbDatabase.SetInitializer<MusicStoreEntities>( new CreateDatabaseIfNotExists<MusicStoreEntities>());

这将使用默认初始化程序,并且只有在找不到数据库时才会创建数据库.实际上有三种可能性:

> CreateDatabaseIfNotExists
> DropCreateDatabaseAlways
> DropCreateDatabaseIfModelChanges

如何将ASP.NET MVC 3的EF代码优先模式禁用并改写为长尾词?

你也可以在Application_Start()中使用它来做一些自定义初始化

Database.SetInitializer<MusicStoreEntities>(new MusicStoreEntityInitializer());

然后,根据您的需要添加一个派生自三种初始化类型之一的新类.

namespace MusicStore.Models { public class MusicStoreEntityInitializer : CreateDatabaseIfNotExists<MusicStoreEntityInitializer> { protected override void Seed(MusicStoreEntity context) { base.Seed(context); // your code to populate db with test data } } }

通过这种设置,您可以获得很大的灵活性.

本文共计426个文字,预计阅读时间需要2分钟。

如何将ASP.NET MVC 3的EF代码优先模式禁用并改写为长尾词?

在开发ASP.NET MVC3音乐商店教程时,若未连接到附加的数据库EF,而是正在SQL EXPRESS中创建新数据库(代码优先),如何避免这种情况发生?

应使用EF的配置来连接到现有数据库,而不是创建新数据库。具体操作是:连接字符串应指向现有数据库,而不是指示创建新数据库。这样配置后,EF会连接到现有数据库,而不是尝试创建一个新的。

我正在做ASP .NET MVC3音乐商店教程而不是连接到附加数据库EF正在SQLEXPRESS中创建一个新数据库(代码优先).如何防止这种情况发生.使用EF的配置应该连接到现有数据库 – 而不是创建新数据库.
我有一个DbContext类,如下所示

using System.Data.Entity; namespace MusicStore.Models { public class MusicStoreEntities:DbContext { public DbSet<Album> Albums { get; set; } public DbSet<Genre> Genres { get; set; } } }

我的web.config有以下连接字符串

<connectionStrings> <add name="MusicStoreEntities" connectionString="data source=.\SQLEXPRESS; Integrated Security=SSPI; AttachDBFilename=|DataDirectory|\MvcMusicStore.mdf; User Instance=true" providerName="System.Data.SqlClient" /> </connectionStrings> 在Application_Start()中,将数据库初始化策略设置为:

DbDatabase.SetInitializer<MusicStoreEntities>( new CreateDatabaseIfNotExists<MusicStoreEntities>());

这将使用默认初始化程序,并且只有在找不到数据库时才会创建数据库.实际上有三种可能性:

> CreateDatabaseIfNotExists
> DropCreateDatabaseAlways
> DropCreateDatabaseIfModelChanges

如何将ASP.NET MVC 3的EF代码优先模式禁用并改写为长尾词?

你也可以在Application_Start()中使用它来做一些自定义初始化

Database.SetInitializer<MusicStoreEntities>(new MusicStoreEntityInitializer());

然后,根据您的需要添加一个派生自三种初始化类型之一的新类.

namespace MusicStore.Models { public class MusicStoreEntityInitializer : CreateDatabaseIfNotExists<MusicStoreEntityInitializer> { protected override void Seed(MusicStoreEntity context) { base.Seed(context); // your code to populate db with test data } } }

通过这种设置,您可以获得很大的灵活性.