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

本文介绍如何使用SPQuery进行SharePoint列表的时间筛选及文档库内容筛选,包括时间格式处理、时间比较设置及文档库中文件夹内容的遍历方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


感谢作者的无私分享。

大家应该常用到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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值