EF缓存

1.

如果POCO中使用了virtual
如果使用Find精确查找,entity的属性,延迟加载属性(关联属性)都能够查询出,查询DB的顺序是:使用Find时立即发出对非延迟的属性的查询,在使用到延迟属性后,发出对延迟属性的查询

1.1如果没有添加virtual标识:
-----------
如果该属性(对象)没有加载到缓存中,则返回null

1.2

如果virtual标识被标识在普通属性(非关联属性)上时,没有实际效果

2.

如果POCO中使用了virtual
如果使用DBContext.Set<T>这种方式
由于使用了virtual,如果关联属性没有被加载到缓存中,则会抛出异常,如果关联属性已经加载到缓存中,则能够查询成功

2.1

如果没有使用virtual标识
----------
如果该项没有存在缓存中,则会直接返回Null

3.

如果使用Set.local()这种方法获得缓存
如果POCO中使用了virtual标志,则如果该关联项没有存在在缓存中,则针对每次请求到DB中查询相应的项

3.1如果没有使用virtual
-------
则如果缓存没有该项,则返回Null

4.如果在CF中没有在关联属性前使用virtual,可以使用ObjectContext的loadProperty()方法追加:

ObjectContext oc = ((IObjectContextAdapter)context).ObjectContext;
oc.LoadProperty<User>(query, user => user.Part);



posted @ 2011-09-23 16:34  wangking1029  阅读(1281)  评论(1编辑  收藏  举报