gpt4 book ai didi

c# - 我可以从 DirectorySearcher 获取超过 1000 条记录吗?

转载 作者:IT王子 更新时间:2023-10-29 03:42:21 26 4
gpt4 key购买 nike

我刚刚注意到结果的返回列表限制为 1000。我的域(巨大的域)中有 1000 多个组。如何获得超过 1000 条记录?我可以从以后的记录开始吗?我可以将其分成多个搜索吗?

这是我的查询:

DirectoryEntry dirEnt = new DirectoryEntry("LDAP://dhuba1kwtn004");
string[] loadProps = new string[] { "cn", "samaccountname", "name", "distinguishedname" };
DirectorySearcher srch = new DirectorySearcher(dirEnt, "(objectClass=Group)", loadProps);
var results = srch.FindAll();

我尝试设置srch.SizeLimit = 2000;,但似乎不起作用。有什么想法吗?

最佳答案

您需要将 DirectorySearcher.PageSize 设置为非零值才能获得所有结果。

顺便说一句,您还应该在使用完 DirectorySearcher 后处理它

using(var srch = new DirectorySearcher(dirEnt, "(objectClass=Group)", loadProps))
{
srch.PageSize = 1000;
var results = srch.FindAll();
}

API 文档不是很清楚,但本质上是:

  • 当您进行分页搜索时,将忽略 SizeLimit,并在您循环访问 FindAll 返回的结果时返回所有匹配结果。结果将从服务器一次检索一个页面。我在上面选择了 1000 的值,但如果愿意,您可以使用较小的值。权衡是:使用较小的 PageSize 会更快地返回每页结果,但在迭代大量结果时需要更频繁地调用服务器。

  • 默认情况下搜索不分页 (PageSize = 0)。在这种情况下,最多会返回 SizeLimit 个结果。

正如 Biri 指出的那样,处理 FindAll 返回的 SearchResultCollection 很重要,否则可能会发生内存泄漏 as described in the Remarks section of the MSDN documentation for DirectorySearcher.FindAll .

在 .NET 2.0 或更高版本中帮助避免这种情况的一种方法是编写一个自动处理 SearchResultCollection 的包装器方法。这可能类似于以下内容(或者可能是 .NET 3.5 中的扩展方法):

public IEnumerable<SearchResult> SafeFindAll(DirectorySearcher searcher)
{
using(SearchResultCollection results = searcher.FindAll())
{
foreach (SearchResult result in results)
{
yield return result;
}
} // SearchResultCollection will be disposed here
}

然后您可以按如下方式使用它:

using(var srch = new DirectorySearcher(dirEnt, "(objectClass=Group)", loadProps))
{
srch.PageSize = 1000;
var results = SafeFindAll(srch);
}

关于c# - 我可以从 DirectorySearcher 获取超过 1000 条记录吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/90652/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com