代码改变世界

[转载]SPQuery特殊运用(时间及文档库类型)

2009-11-24 14:34  Virus-BeautyCode  阅读(818)  评论(0编辑  收藏  举报

感谢作者的无私分享。

大家应该常用到SPQuery来进行筛选MOSS列表中的内容.

最近用到时间筛选、存在文件夹的文档库内容(不是列表库)筛选就出现部分问题。下面做个笔记。

首先我们温习下SPQuery语句,用大家都熟悉的SQL语法来和它做个比较,如下表:SPQuery SQL
<Where></Where> Where
<And></And> And
<Or></Or> Or
<Eq></Eq> =
<Geq></Geq> >=
<Gt></Gt> >
<Leq></Leq> <=
<Lt></Lt> <
<Neq></Neq> !=
<IsNotNull></IsNotNull> !=null
<IsNull></IsNull> = null
<Contains><Contains> IN
<BeginWith></BeginWith> Like '开始信息%'
<OrderBy></OrderBy> Order By



SPQuery中的时间筛选:

1、处理时间格式,通过SPUtility.CreateISO8601DateTimeFromSystemDateTime()将时间转为 “yyyy-mm-ddThh:mm:ssZ”这个格式

2、进行时间比较,需要添加 IncludeTimeValue='TRUE'

SPQuery文档库中的筛选:

添加query.ViewAttributes = "Scope='Recursive'" 遍历到文档库中的所有文件夹内容



下面以查找昨天到现在修改的文件为例,如下:

SPList list = web.Lists[DocListName];

string date = SPUtility.CreateISO8601DateTimeFromSystemDateTime(DateTime.Now.AddDays(-1)); //查找昨天到现在修改的文件
SPQuery query = new SPQuery();
query.Query = "<Where><Gt><FieldRef Name=\"Last_x0020_Modified\"/><Value Type=\"DateTime\" IncludeTimeValue='TRUE'>" + date + "</Value></Gt></Where>";
query.ViewAttributes = "Scope='Recursive'"; //设置范围为递归,包含子文件夹
SPListItemCollection items = list.GetItems(query);