首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SharePoint:验证SPQuery

SharePoint:验证SPQuery
EN

Stack Overflow用户
提问于 2011-04-27 07:58:31
回答 1查看 2.2K关注 0票数 0

我正在为我的公司编写一个内部应用程序接口,允许用户在SharePoint CAML查询中传递。在我的函数中,我处理用户的查询,并向其添加一些额外的元素,然后使用最终的查询从SharePoint检索所需的数据。

示例:

用户传入:

代码语言:javascript
复制
<Query>
   <Where>
      <Eq>
         <FieldRef Name='Category' />
         <Value Type='Choice'>Bug</Value>
      </Eq>
   </Where>
</Query>

在内部,我将查询修改为:

代码语言:javascript
复制
<Query>
   <Where>
      <And>
         <Eq>
            <FieldRef Name='Category' />
            <Value Type='Choice'>Bug</Value>
         </Eq>
         <Eq>
            <FieldRef Name='AssignedTo' />
            <Value Type='Integer'><UserID /></Value>
         </Eq>
      </And>
   </Where>
</Query>

您认为验证用户发送的查询的最佳方式是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-04-27 08:16:45

如果您要允许的查询受到相当大的限制,那么构建一个模式来表示有效的查询可能是一个很好的方法。然后,您就可以根据该模式查看它们的xml是否有效。另外,我知道您可以在代码中使用CAML Builder dll。我现在还找不到这样的例子,但也许有一种方法可以在try/catch块中使用它的CAML构建方法来阻止构建无效查询。

此外,我认为您可能需要注意这样一个事实,即CAML查询的FieldRef将需要使用字段的内部名称来构建,该字段的内部名称可能与显示名称不同。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5797864

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档