SharePoint CAML使用用户名查询“创建者”字段

时间:2010-05-20 12:07:21

标签: sharepoint caml

嘿,我有一个管理员表单,他们插入一个用户名(“domain \ name”),代码从中获取并设置一些信息。

这是一个庞大的项目,有些列表包含用户名作为字符串(“domain \ name”),但有些列表只依赖于“创建者”列,该列是自动创建的。

我想知道使用用户名字符串查询这些列表的最快方法是什么。我尝试使用与我用于第一种列表的查询相同的查询,但它显然不起作用 -

<Where><Eq><FieldRef Name='UserName'/><Value Type='Text'>domain\\username</Value></Eq></Where>

谢谢。

2 个答案:

答案 0 :(得分:17)

有两个不同的“创建者”字段,一个用于所有项目,另一个专门用于文档库(“文档创建者”)。 “创建者”字段的内部名称是“作者”,因此<FieldRef Name='Author'/>将是最好的开始。第二个字段是文档库中实际文件的作者,其内部名称为“Created_x0020_By”。从你的情景来看,我觉得你只需要前者,但后者很高兴知道,因为存储在其中的数据是不同的。

“Created By”是一个用户字段,因此其数据的字符串版本为ID;#Full Name。同时,“文档创建者”是单行文本的文本字段,其数据存储为实际用户名(如果适用,则使用域)。因此,您的上述查询将适用于文档库并在<FieldRef Name='Created_x0020_By'/>上搜索。但是,如果要搜索“创建者”字段,则必须有点棘手,但您应该能够通过引用用户的SharePoint ID来完成它。以下是我正在使用的不同用户字段查询的示例,用于比较。

<Eq><FieldRef Name='AssignedTo' /><Value Type='Integer'><UserID Type='Integer' /></Value></Eq>

这专门过滤了当前用户。要将其用于您的目的,请将“AssignedTo”替换为“作者”,将<UserID Type='Integer' />替换为相关用户的ID。

答案 1 :(得分:8)

我会推荐以下内容:

  1. 通过调用EnsureUser方法获取SharePoint用户,即:

     SPUser myUser = SPContext.Current.Web.EnsureUser(@"DOMAIN\USERNAME");
    
  2. 使用SharePoint用户的ID查询列表:

     SPQuery spQuery = new SPQuery();
     StringBuilder queryString = new StringBuilder(String.Empty);
     queryString.Append(@"<Where>");
     queryString.Append(@"   <Eq>");
     queryString.Append(@"       <FieldRef ID=""{1df5e554-ec7e-46a6-901d-d85a3881cb18}"" LookupId=""True"" />"); //Author Field
     queryString.Append(@"       <Value Type=""Lookup"">" + myUser.ID + @"</Value>");
     queryString.Append(@"   </Eq>");
     queryString.Append(@"</Where>");
     spQuery.Query = queryString.ToString();
    
  3. 针对列表

    触发查询
    myList.GetItems(spQuery);