我的Telerik OpenAccess ORM存在一些(更多)问题。这次是在将查询策略应用于查询的区域。这是代码......
using (DAL.DarkRoomDB ctx = new DarkRoomDB())
{
//
// Set the resulting object to include the contents of the package
FetchStrategy strategy = new FetchStrategy();
strategy.LoadWith<DeliverablePackageEntity>(c => c.PackageContents);
strategy.LoadWith<DeliverablePackageContentEntity>(c => c.Deliverable);
strategy.LoadWith<DeliverablePackageContentEntity>(c => c.DeliverablePackage);
strategy.MaxFetchDepth = 3;
ctx.FetchStrategy = strategy;
//
// get the package that matches the SKU
DataStoreRepository<DeliverablePackageEntity> repo = DataStoreRepository<DeliverablePackageEntity>.GetInstance(ctx);
DeliverablePackageEntity entity = repo.GetEntityList(c => c.PackageSku == SKU).FirstOrDefault();
//
// Create a DISCONNECTED COPY of the entity
copy = ctx.CreateDetachedCopy<DeliverablePackageEntity>(entity, strategy);
}
ret = EntityToDomainMapper.Map<DeliverablePackageEntity, DeliverablePackage>(copy);
return ret;
当我运行此功能时,我希望预先加载 DeliverablePackageEntity 的 PackageContents 。当我在调试器中查看实体变量时,它告诉我“扩展后将枚举属性的内容”,这会告诉我该属性尚未预先填充,这就是我认为FetchStrategy的目的。
我错过了什么吗?
答案 0 :(得分:1)
此行为是正常的,因为实体对象的导航属性属于IEnumerable类型。因此,即使它们被预先加载到内存中,您也需要通过它们进行枚举才能访问它们。
通过检查访问它们时是否生成了SQL脚本,可以验证FetchStrategy中指定的导航属性是否已预先加载。
考虑以下示例,其中预先加载了Car对象的相关RentalOrders。在执行ToList()方法时,它们将被枚举,但executionScript将保持为空,因为它们已由FetchStrategy预加载:
using (EntitiesModel1 context = new EntitiesModel1())
{
FetchStrategy loadWithRentalOrders = new FetchStrategy();
loadWithRentalOrders.LoadWith<Car>(car => car.RentalOrders);
context.FetchStrategy = loadWithRentalOrders;
Car firstCar = context.Cars.First();
context.Log = new StringWriter();
List<RentalOrder> relatedOrders = firstCar.RentalOrders.ToList();
//should be empty
string executedScript = context.Log.ToString();
}
我希望这会有所帮助。