Telerik Open Access FetchStrategy似乎不适用于我的查询

时间:2015-08-24 15:55:56

标签: c# telerik telerik-open-access

我的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的目的。

我错过了什么吗?

1 个答案:

答案 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();
}

我希望这会有所帮助。