CAML中比较日期时间类型

简介:

在做Sharepoint的列表查询的时候,经常要用到CAML,今天我在做一个工作流授权列表的查询,里面要求根据人员、工作流名称、授权开始时间和授权结束时间找到对应的授权人,没有找到就返回本人。使用CAML QueryBuilder生成了查询,然后修改了其中的对应的变量,进行查询。结果发现查询结果有问题。原来是在CAML中使用的日期类型的表示必须是一种国内很少用的特殊的格式,,形如"2009-04-09T15:11:20Z"网上找了一下,使用SPUtility.CreateISO8601DateTimeFromSystemDateTime

这个函数就可以生成这种格式,当然,其实是有Datetime.ToString(“格式”)也是可以的。查询的CAML是这样的:

string dString = SPUtility.CreateISO8601DateTimeFromSystemDateTime(DateTime.Now);
q.Query =
@"<Where>
<And>
<And>
<And>
<Contains>
<FieldRef Name='_x5de5__x4f5c__x6d41_' />
<Value Type='LookupMulti'>" + wfName + @"</Value>
</Contains>
<Eq>
<FieldRef Name='Author' LookupId='TRUE'/>
<Value Type='User'>" + us.ID + @"</Value>
</Eq>
</And>
<Lt>
<FieldRef Name='_x5f00__x59cb__x65f6__x95f4_'/>
<Value Type='DateTime'>" + dString + @"</Value>
</Lt>
</And>
<Gt>
<FieldRef Name='_x7ed3__x675f__x65f6__x95f4_'/>
<Value Type='DateTime'>" + dString + @"</Value>
</Gt>
</And>
</Where>";

这样做以后进行查询,大部分情况都对了,但是有时候还是会不对,那就是在当天的时候。比如我设置了开始时间是2009-4-9 10:00:00,而现在的时间是9号的14点,但是查询却没有返回结果,经过多次试验,终于找到原因,原来是根本没有对时间字段进行比较,而只是对日期进行比较,由于4月9号并不大于4月9号,所以就找不到结果。

要进行时间字段的比较,那么需要在CAML中的Value字段上添加IncludeTimeValue='TRUE',添加后就可以进行时间字段的比较了。

string dString = SPUtility.CreateISO8601DateTimeFromSystemDateTime(DateTime.Now);
q.Query =
@"<Where>
<And>
<And>
<And>
<Contains>
<FieldRef Name='_x5de5__x4f5c__x6d41_' />
<Value Type='LookupMulti'>" + wfName + @"</Value>
</Contains>
<Eq>
<FieldRef Name='Author' LookupId='TRUE'/>
<Value Type='User'>" + us.ID + @"</Value>
</Eq>
</And>
<Lt>
<FieldRef Name='_x5f00__x59cb__x65f6__x95f4_'/>
<Value Type='DateTime' IncludeTimeValue='TRUE'>" + dString + @"</Value>
</Lt>
</And>
<Gt>
<FieldRef Name='_x7ed3__x675f__x65f6__x95f4_'/>
<Value Type='DateTime' IncludeTimeValue='TRUE'>" + dString + @"</Value>
</Gt>
</And>
</Where>";

这里我写的时候,犯了个错,把IncludeTimeValue='TRUE'写到FieldRef中去了,以为就跟LookupId='TRUE'一样,结果老是查询不比较时间字段,这里大家也要注意啊。

另外,再附上一个CAML语法:

CAML语法-Query写法

元素 说明
And 并且
BeginsWith 以某字符串开始的
Contains 包含某字符串
Eq 等于
FieldRef 一个字段的引用 (在GroupBy 中使用)
Geq 大于等于
GroupBy 分组
Gt 大于
IsNotNull 非空
IsNull 空
Leq 小于等于
Lt 小于
Neq 不等于
Now 当前时间
Or 或
OrderBy 排序
Today 今天的日期
TodayIso 今天的日期(ISO格式)
Where Where子句

目录
相关文章
|
10天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1216 5
|
9天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1181 87
|
10天前
|
云栖大会
阿里云云栖大会2025年9月24日开启,免费申请大会门票,速度领取~
2025云栖大会将于9月24-26日举行,官网免费预约畅享票,审核后短信通知,持证件入场
1776 12
|
19天前
|
人工智能 运维 安全
|
2天前
|
资源调度
除了nrm-pm,还有哪些工具可以管理多个包管理器的源?
除了nrm-pm,还有哪些工具可以管理多个包管理器的源?
230 127
|
10天前
|
弹性计算 Kubernetes jenkins
如何在 ECS/EKS 集群中有效使用 Jenkins
本文探讨了如何将 Jenkins 与 AWS ECS 和 EKS 集群集成,以构建高效、灵活且具备自动扩缩容能力的 CI/CD 流水线,提升软件交付效率并优化资源成本。
362 0