SPQuery特殊运用(时间及文档库类型)

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

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

首先我们温习下SPQuery语句,用大家都熟悉的SQL语法来和它做个比较,如下表:

SPQuerySQL
<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);

转载于:https://www.cnblogs.com/Anlycp/archive/2009/11/04/1595948.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值