首页 > 解决方案 > 如果 CAML 查询被修改或删除,SPList 不返回结果

问题描述

我有一个SharePoint PowerShell从列表中获取项目的脚本。

我正在更改CAML不同输出的查询。

但是,在更改或删除CAML查询时,list.GetItems()返回0结果的方法,我不知道为什么会这样。

下面是我的代码片段:

Add-PSSnapin Microsoft.SharePoint.PowerShell -ErrorAction SilentlyContinue

#Set config variables
$baseUrl="http://test.com/"
$listName ="Lists/FilePlan"

#Get Web and List Objects
$web = Get-SPWeb $baseUrl
$list = $web.GetList($listName)

#Define the CAML Query
$queryOriginal = New-Object Microsoft.SharePoint.SPQuery
$queryOriginal.Query = "@
<Where>
    <Eq>
        <FieldRef Name='ContentType' />
        <Value Type='Text'>Folder Content Type</Value>
    </Eq>
</Where>"

$queryModified = New-Object Microsoft.SharePoint.SPQuery
$queryModified.Query = "@
<Where>
    <Eq>
        <FieldRef Name='ContentType' />
        <Value Type='Text'>Document Content Type</Value>
    </Eq>
</Where>"

#Get List Items matching the query
$items = $list.GetItems($queryOriginal)  //result
$items2 = $list.GetItems($queryModified) //zero result*****
$items3 = $list.GetItems()               //zero result*****

编辑:

尝试使用<Neq>但也无济于事。

标签: listpowershellsharepointcaml

解决方案


您可以检查下面的 PowerShell 脚本。

#Set config variables
$baseUrl="http://test.com/"
$listName ="FilePlan"

#Get Web and List Objects
$web = Get-SPWeb $baseUrl
$list = $web.Lists[$listName]

$items = $list.Items
$items.Count

然后您可以检查 ContentType 是否适合此列表。您可以提供有关列表(自定义列表或文档库以及此列表的所有内容类型)的更多信息以供进一步研究。


推荐阅读