5

我正在尝试从SharePoint库中获取所有文件夹和文件,执行单个请求。

CamlQuery query = new CamlQuery();
query.ViewXml = "<View Scope='RecursiveAll' />";
var libraryName = "Specific Documents";

ListItemCollection itemsRaw = clientContext.Web.Lists.GetByTitle(libraryName).GetItems(query);
clientContext.Load(itemsRaw);
clientContext.ExecuteQuery();

此代码运行良好,因此我在指定库中有一个所有文件夹和文件的列表。

似乎文件详细信息是以惰性方式加载的。仅来自详细信息层次结构的第一级。但我不知道如何,FieldValues集合充满了数据。

列表项详细信息

我看到ListItem ContentType.Name没有初始化。

ContentType 名称未初始化

是否有可能以某种方式更新查询,该方式将在此单个调用中加载ContentType的数据。

或者唯一的可能性是遍历所有文件并为特定文件加载 ContentType ?

我通过以下方式做到了这一点:

foreach(var listItem in listItemCollection)
{
    context.Load(listItem, k => k.ContentType);
    context.ExecuteQuery();
    var contentTypeName = listItem.ContentType.Name;
}

但如果可能的话,我将在一次调用中获取此信息,而无需在集合中迭代并启动对ClientContext的多次调用。

PS:我是SharePoint编程新手。我只是想修复一个错误。

谢谢!

4

2 回答 2

4

正如您在 SharePoint 客户端对象模型 (CSOM) 中正确注意到的那样,ClientRuntimeContext.Load 方法不会检索客户端对象的所有属性。

ClientRuntimeContext.Load 方法具有以下语法:

public void Load<T>(
    T clientObject,
    params Expression<Func<T, Object>>[] retrievals
)
where T : ClientObject        

其中retrievals参数用于指定必须检索的属性。

其次,由于 SharePoint CSOM 支持Request Batching,您的示例可以修改为以下示例:

foreach (var item in items)
{
    ctx.Load(item, i => i.ContentType);
}
ctx.ExecuteQuery();

注意:本例中只向服务器提交一次请求

但是提供的示例仍然需要对服务器的两个请求:

  • 检索列表项
  • 检索列表项的内容类型

并且可以通过将对服务器的请求减少到一个来从性能角度 进行改进。

最后一个例子

该示例演示了如何检索列表项并明确指定要检索的属性:

 var listTitle = "Documents";
 var query = new CamlQuery();
 query.ViewXml = "<View Scope='RecursiveAll' />";

 var items = ctx.Web.Lists.GetByTitle(listTitle).GetItems(query);
 ctx.Load(items,icol => icol.Include(
                i => i.ContentType,
                i => i.FieldValues));
 ctx.ExecuteQuery();
于 2015-02-13T20:11:29.503 回答
0

最后一个示例不起作用(在 SP2010 中)。

有一个例外“不支持查询表达式”如果您明确说明所有必填字段,则以下解决方案有效。

var listTitle = "Documents";
var query = new CamlQuery();
query.ViewXml = "<View Scope='RecursiveAll' />";

var items = ctx.Web.Lists.GetByTitle(listTitle).GetItems(query);

string[] fieldsToMigrate = new string[] { "Title", "FieldA", "FieldB" };
ctx.Load(items, a => a.Include(b => b.ContentType, b => b["FileRef"]));
foreach (var f in fieldsToLoad) {
    ctx.Load(items, includes => includes.Include(a => a[f]));
}

ctx.ExecuteQuery();
于 2016-05-03T07:49:43.227 回答