有两个不同的“创建者”字段,一个用于所有项目,另一个专用于文档库(“创建文档”)。 “创建者”字段的内部名称是“作者”,因此<FieldRef Name='Author'/>
将是最好的开始。第二个字段是文档库中实际文件的作者,其内部名称为“Created_x0020_By”。从你的情景判断,我有一种感觉,你只需要前者,但无论如何,后者知道的很好,因为存储在它们中的数据是不同的。
“创建者”是一个用户字段,所以其数据的字符串版本是ID;#Full Name
。同时,“文档创建者”是单行文本的文本字段,其数据作为实际用户名(包含域,如果适用)存储。因此,您的上述查询将适用于文档库并在<FieldRef Name='Created_x0020_By'/>
上进行搜索。但是,如果您想在“创建者”字段上进行搜索,则必须有点棘手,但您应该可以通过引用用户的SharePoint ID来完成它。以下是我用于比较的一个不同的用户字段查询的示例。
<Eq><FieldRef Name='AssignedTo' /><Value Type='Integer'><UserID Type='Integer' /></Value></Eq>
这个具体过滤了当前用户。要将其用于您的目的,请将'AssignedTo'替换为'作者',并用相关用户的ID替换<UserID Type='Integer' />
。
谢谢。我有第一个场景,即试图通过作者列查询简单列表,只有一个用户名。我设法创建了一个SPUser对象,并用“Author”和user.ID尝试了你的查询,但是我得到一个异常,说“当转换为nvarchar值'SomeFirstname SomeLastname'为数据类型int。”时,转换失败,其中“SomeFirstname SomeLastname”是列表中不是用户名的名称。 希望你的帮助:) – yellowblood 2010-05-22 11:49:37
nvm,修复它。当按ID查询“作者”列时,需要为“FieldRef”标签添加一个“LookupId ='True'”属性。 工作,非常感谢! – yellowblood 2010-05-22 12:23:34