Sharepoint客户端对象模型查询过滤器不起作用

时间:2012-01-14 01:21:02

标签: c# .net sharepoint client-object-model

我正在使用客户端对象模型来查询列表中的记录。它按标题进行过滤,这是唯一的,所以我希望它只返回一条记录,但它会返回整个列表。

以下是代码:

FieldLookupValue result = new FieldLookupValue();
List list = web.Lists.GetByTitle(lookupSourceList);
var query = new CamlQuery
                {
                   ViewXml =
                        string.Format(
                          "<View><Where><Eq><FieldRef Name='Title' /><Value Type='Text'>{0}</Value></Eq></Where></View>",
                           lookupValue)
                };
var ls = list.GetItems(query);
ctx.Load(ls, li => li);
ctx.ExecuteQuery();
if (ls.Count == 1)
{
    result.LookupId = ls[0].Id;
}

return result;

这有什么问题?为什么它会返回整个列表?

1 个答案:

答案 0 :(得分:3)

您错过了。

周围的查询节点

看起来应该是这样的

<View>
  <Query>
    <Where>
    <!-- -->
    </Where>
  </Query>
</View>

CAML有时候不仅仅是严格的!试试吧。

和Thorsten