1. 程式人生 > >Entity Framework DataSet注入資料分析

Entity Framework DataSet注入資料分析

一般的.Net裡用到ORM框架EF,都會新建一個Model比如Movie

public class Movie
{
public int Id {get;set;}
public string Name {get;set;};
}

然後是DBContext繼承類
比如:
MovieDbContext:DbContext
{
DbSet Movies {get;set;}
}

在我們用的時候可以直接例項化MovieDBContext
MovieDbContext MT=new MovieDbContext();
然後比如新增 MT.Movies.Add(new Movie{1,”Tang”});

實際上這個泛型型別為DbSet的Movies沒有被顯式賦值比如Movies=Values;

他這個 Movies是何時被例項化的呢?
實際上當你New MovieDbContext的時候,預設建構函式會呼叫:InitializeLazyInternalContext(new LazyInternalConnection(this, GetType().DatabaseName()));

InitializeLazyInternalContext方法裡面有一個DiscoverAndInitializeSets()函式。這個函式例項化了 new DbSetDiscoveryService(this).InitializeSets();
就是在這個InitializeSets()方法裡面他對MovieDbContext進行了反射獲取到當前public訪問級別的泛型方法,然後獲取到泛型型別,通過Lmada表示式呼叫Set屬性器,給Movies賦值

程式碼如下:
var setter = propertyInfo.Setter();
if (setter != null && setter.IsPublic)
{
var setMethod = SetMethod.MakeGenericMethod(entityType);

                            var newExpression = Expression.Call(dbContextParam, setMethod);
                            var setExpression = Expression.Call(
                                Expression.Convert(dbContextParam, _context.GetType()), setter, newExpression);
                            initDelegates.Add(
                                Expression.Lambda<Action<DbContext>>(setExpression, dbContextParam).Compile());
                        }