我正在尝试过滤SharePoint列表,以便只有具有"管理"字段(其中包含字符串(的项目(如"是"(才会显示,但是每当我到达ctx时。ExecuteQuery(( 语句,我的程序崩溃了。我相信我的 CAMLQuery 结构正确,所以我不确定我只是用错了还是遗漏了什么。任何帮助都会很棒!谢谢!我目前拥有的代码发布如下:
Web myWeb = ctx.Web;
List myList = myWeb.Lists.GetByTitle("Company Employees");
SPClient.View view = myList.DefaultView;
CamlQuery qry = new CamlQuery();
qry.ViewXml = "<Query>" + "< Where >" + "<Eq>" + "< FieldRef Name='Management'/>" + "< Value Type='Text'>Yes</ Value >" + "</Eq>" + "</ Where >" + "</ Query >";
myList.GetItems(qry);
ListItemCollection listItems = myList.GetItems(qry);
ctx.Load(listItems);
ctx.ExecuteQuery();
您的代码似乎缺少<View>
标记,该标记将环绕 CAML 中的<Query>
标记。
添加<View>
根元素后,正确的 CAML XML 如下所示:
qry.ViewXml =
"<View>"+
"<Query>"+
"<Where>"+
"<Eq>"+
"<FieldRef Name='Management'/>"+
"<Value Type='Text'>Yes</Value>"+
"</Eq>"+
"</Where>"+
"</Query>"+
"</View>";
其他故障排除
为了帮助进行故障排除,您可以尝试通过 JavaScript 客户端对象模型运行相同的查询。
- 在 Internet Explorer 中访问 SharePoint 网站并按F5以打开开发人员工具。
- 在"控制台"选项卡上,输入以下代码行,然后一次执行一行(通过按 Enter 或Ctrl+Enter(:
-
var ctx = new SP.ClientContext();
var list = ctx.get_web().get_lists().getByTitle("Company Employees");
var qry = new SP.CamlQuery();
qry.set_viewXml("<View><Query><Where><Eq><FieldRef Name="Management"/><Value Type="Text">Yes</Value></Eq></Where></Query></View>");
var items = list.getItems(qry);
ctx.load(items);
ctx.executeQueryAsync(function(){alert("success!");},function(sender,args){alert(args.get_message());});
发布帮助解决方案 感谢您的帮助,我能够弄清楚如何使用以下代码创建具有所需过滤的新视图。主要问题是 Caml 查询 - 在创建视图之前,我必须删除 and 标签,然后删除几行。以下是我的工作解决方案:
Web myWeb = ctx.Web;
List myList = myWeb.Lists.GetByTitle("Company Employees");
SPClient.View view = myList.DefaultView;
CamlQuery qry = new CamlQuery();
qry.ViewXml =
"<Where><Eq><FieldRef Name="Management"/><Value Type='Text'>Yes</Value></Eq></Where>";
ViewCollection viewColl = myList.Views;
string[] viewFields = { "Title", "Promoted", "Intern", "Management" };
ViewCreationInformation creationInfo = new ViewCreationInformation();
creationInfo.Title = "Management";
creationInfo.RowLimit = 50;
creationInfo.ViewFields = viewFields;
creationInfo.ViewTypeKind = ViewType.None;
creationInfo.SetAsDefaultView = false;
creationInfo.Query = qry.ViewXml;
viewColl.Add(creationInfo);
ctx.ExecuteQuery();