代码改变世界

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

  Virus-BeautyCode  阅读(824)  评论(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);
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2008-11-24 使用VS进行工作流开发系列博客5-Developing Workflows in VS: Part 4 - Design and Bind Your Forms
2008-11-24 使用VS进行工作流开发系列博客4-Developing Workflows in VS: Part 3 - Five Steps for Developing Your Workflow
2008-11-24 使用VS进行工作流开发系列博客3-Developing Workflows in VS: Part 2 - Planning Your Workflow: Two Things to Keep in Mind
2008-11-24 使用VS进行工作流开发系列博客2-Developing Workflows in VS: Part 1 - Workflow Objects and A Crash Course on Mechanics
2008-11-24 使用VS进行工作流开发系列博客1-"So You Want to Develop Custom Workflows in Visual Studio..." - The Blog Series
2008-11-24 微软sharepoint产品组博客——使用VS进行工作流开发系列博客
点击右上角即可分享
微信分享提示