【轉】讓Entity Framework再也不私闖sys.databases

這裏的「私闖sys.databases」是指Entity Framework默認發起的查詢:SELECT Count(*) FROM sys.databases WHERE [name]=N'數據庫名'html

注:本文針對的是Entity Framework Code First場景,Entity Framework的版本是4.1與4.2。web

3月份的時候在揭開Entity Framework LINQ查詢的一點面紗一文中發現了Entity Framework的兩個幕後交易。數據庫

第一個交易(私闖sys.databases):ide

SELECT  Count ( * )  FROM  sys.databases  WHERE  [ name N ' CNBlogsData '

第二個交易(私自打探數據庫的信息):ui

SELECT  TOP  ( 1 ) 
[ Extent1 ] . [ Id AS  [ Id ] , 
[ Extent1 ] . [ ModelHash AS  [ ModelHash ]
FROM  [ dbo ] . [ EdmMetadata AS  [ Extent1 ]
ORDER  BY  [ Extent1 ] . [ Id DESC

當時經過modelBuilder.Conventions.Remove<IncludeMetadataConvention>();阻止了第二個交易,但未能找到方法阻止第一個交易。this

記得當時用的是Entity Framework 4.0,後來微軟發佈了EF4.1和EF4.2。那咱們來看看Entity Framework有沒有改邪歸正。spa

結果發現,只改了一半,第二個交易「浪子回頭」,而第一個交易「賊心不改」。code

代碼世界是完美世界,決不容許這樣的行爲,必定要將之繩之以法。orm

通過今天下午的努力,終於找到了這根「繩子」:htm

Database.SetInitializer<DbContextTypeName>(null);

示例代碼以下:

複製代碼
public class EfUnitOfWork : DbContext, IUnitOfWork
{
public EfUnitOfWork()
{
Database.SetInitializer<EfUnitOfWork>(null);
}

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
}
}
複製代碼

能夠看出,Entity Framework「私闖sys.databases」的目的是爲了在根據實體生成數據庫時,檢查是否存在同名的數據庫。

而咱們的應用場景根本不須要Entity Framework生成數據庫,因此將之繩之以法是「名正言順」。

相關文章
相關標籤/搜索