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);