我想从CAML查询过滤到ListItem.ContentType.Hidden。
使用SharePoint To Linq就像本代码一样。
var query = from item in list.GetItems(CamlQuery.CreateAllItemsQuery())
where item.ContentType.Hidden == false select item;
如果我查看纯CAML查询,我应该编写代码吗?
这是一个简单的问题。
谢谢。
答案 0 :(得分:4)
您无法在纯CAML查询中检查Hidden
属性。在CAML中,只有ContentType的名称和ID可用(Fields ContentType 和 ContentTypeID )。
如果只有少数几个必须排除的隐藏内容类型,您可以先加载这些隐藏的内容类型并将其排除在CAML查询中:
提取隐藏的内容类型:
SPWeb web = // ...
IEnumerable<string> contentTypeIds = web.AvailableContentTypes
.Cast<SPContentType>()
.Where(ct => ct.Hidden)
.Select(ct => ct.Id.ToString());
CAML查询:
<Where>
<And>
<Neq>
<FieldRef Name='ContentTypeID'/>
<Value Type='Text'>[HiddenContentTypeId]</Value>
</Neq>
<Neq>
<FieldRef Name='ContentTypeID'/>
<Value Type='Text'>[AnotherHiddenContentTypeId]</Value>
</Neq>
</And>
<!-- more hidden content types -->
</Where>