1,最近的项目中遇到一个需求,站点中有几十个列表,其中每5,6个列表属于一个模块下的。客户的需求是,首页上显示一个模块下所有列表数据的前5条,并按创建时间排序。

2,刚刚考虑到这块的实现方法时,用的是DataTable存储每个列表的前五条,然后DataTable在排序,取前五条,这样做的缺点显而易见,需要多次访问列表,然后取出的数据创建时间排序还不一定是正确的。后来发现SharePoint可以跨列表查询,解决这个问题真是太方便了。

3,

static void Main(string[] args)
{
SPSecurity.RunWithElevatedPrivileges(delegate()
{
using (SPSite site = new SPSite("http://sp2013/sites/DYZX"))
{
using (SPWeb web = site.OpenWeb())
{
//声明Query对象
SPSiteDataQuery query = new SPSiteDataQuery();
query.Query = "<OrderBy><FieldRef Name=\"Created\" Ascending=\"False\" /></OrderBy>";
query.RowLimit = 5;
query.Webs = "<Webs Scope='SiteCollection' />";
query.ViewFields = "<FieldRef Name='Title' /><FieldRef Name='Created' /><ProjectProperty Name='Title' /><ListProperty Name='Title' />";
query.Lists = "<Lists>" +
"<List ID=\"3f3f85f0-b4a2-4ef3-9e59-56d3ee9f79ed\" />" +
"<List ID=\"498e313f-f54f-4919-9651-54e78c59f3c5\" />" +
"</Lists>";
DataTable dt = web.GetSiteData(query);
foreach (DataRow dr in dt.Rows)
{
foreach (DataColumn dc in dt.Columns)
{
Console.WriteLine(dc.ColumnName+":"+dr[dc.ColumnName].ToString());
}
}
}
}
});
}

4,query.webs:

此元素的属性只有一个:Scope。能赋予它的值有3个吧,尽管MSDN上说只有2个…..

"<Webs Scope='SiteCollection' />",包含当前网站所在的网站集(Site)下所有网站(Web)以及子网站(Web)

"<Webs Scope='Recursive' />",包含当前网站(Web)以及其下的所有子网站(Web)

默认,仅仅包含当前网站(Web)

5,query.Lists = "<Lists ServerTemplate=\"107\" />";
     query.Lists = "<Lists BaseType=\"0\" />";
     query.Lists = "<Lists Hidden = \"true\" />";

此元素将定义你在文档库(Document Libraries)或者列表(Lists)里的搜索范围。 属性有4个:BaseType、ServerTemplate、Hidden、MaxListLimit 此外,子元素有两个:List、WithIndex。使用子元素可以将搜索条件限制在比较小的范围之内。 下面是关于属性的介绍。

(1) BaseType (例:"<Lists BaseType='1'/>")

必须要注意的是这个属性的默认值为"<Lists BaseType='0'/>",也就是说缺省或者该属性设置出错时会查询文档库以外的所有列表。

(2)ServerTemplate (例: "<Lists ServerTemplate='850'/>")搜索指定类型的列表(850为页面库列表类型)。这个属性的值出错时会以默认值进行查询。

(3) Hidden (例:"<Lists ServerTemplate='850' Hidden='TRUE'/>") 设定能否搜索隐藏列表。默认是搜索所有非隐藏的列表。

(4) MaxListLimit(例:"<Lists BaseType='1' MaxListsLimit='500'/>") 定义搜索的列表的总数,当超过这个数字时,SPSiteDataQuery会抛出一个SPException的例外。这个属性的默认值为1000。当把此属性设置为0时,那么搜索的列表数目将不会受到限制。

(5)子元素List(例:上面的代码即时使用的子元素List),定义搜索列表的Guid,只在指定的列表中搜索。

参考博文:http://www.cnblogs.com/jinho/archive/2011/03/15/1985448.html

SharePoint中跨列表查询的更多相关文章

  1. SHAREPOINT - CAML列表查询

    首先要了解的是CAML(Collaboration Application Markup Language)不仅仅是用在对列表.文档库的查询,字段的定义,站点定义等处处使用的都是CAML. 简单的提一 ...

  2. [总结]SHAREPOINT - CAML列表查询(上)

    首先要了解的是CAML(Collaboration Application Markup Language)不仅仅是用在对列表.文档库的查询,字段的定义,站点定义等处处使用的都是CAML. 简单的提一 ...

  3. SharePoint 2013 列表多表联合查询

    在SharePoint的企业应用中,遇到复杂的逻辑的时候,我们会需要多表查询:SharePoint和Sql数据表一样,也支持多表联合查询,但是不像Sql语句那样简单,需要使用SPQuery的Joins ...

  4. SharePoint 2013 列表关于大数据的测试&lt;二&gt;

    1.给测试列表添加查阅项字段,100个,代码如下: 2.插入测试数据的方法,注意查阅项字段的格式,代码如下: 3.插入10w条数据,时间花费如下(不建议List[LISTNAME].Items.Add ...

  5. Sharepoint 2013列表视图和字段权限扩展插件(免费下载)!

    记得2014年春节期间,有博客园的网友通过QQ向我咨询Sharepoint 2013列表视图和字段权限扩展,因为之前他看到我博客介绍Sharepoint 2010列表视图和字段的权限控制扩展使用,问有 ...

  6. sharepoint 2013 列表和库标签 元数据导航配置(2)

    接前面提到的,如何创建一个术语库.sharepoint 2013 列表和库标签 元数据导航配置(1), 现在要做的,就是如何在自定义或者文档库中使用这个术语库,实现标签功能,通过这些标签,找到对应的文 ...

  7. atitit.提升开发效率---MDA 软件开发方式的革命(5)----列表查询建模

    )----列表查询建模 1. 配置条件字段@Conditional 1 2. 配置条件字段显示类型为range----@Conditional(displayType = displayType.ra ...

  8. 【Javascript】列表查询页面,简单地保存上一次查询的查询参数

    开发中经常做一些查询参数 + 列表参数的功能,这些功能有时候需提供导出Excel,或带超链接到其他明细页面的功能点. 在一些交互性要求严格的系统,需求方会要求: 用户第一个输入某些查询条件进行列表查询 ...

  9. SharePoint 2013 列表启用搜索

    转载自:http://www.cnblogs.com/jianyus/p/3470117.html SharePoint 2013列表搜索的设置,只是进行完全爬网,就可以使用.如果开启爬网不是很熟练可 ...

随机推荐

  1. JavaScriptPolyfillShim 在JavaScript中Shim和Polyfill有什么区别?

    在JavaScript的世界里,有两个词经常被提到,那就是Shim和Polyfill,它们指的都是什么,又有什么区别?在本文中,将简短的给大家介绍他们之间的联系和区别.Shim一个shim就是一个库, ...

  2. iOS开发——UI基础-按钮内边距,图片拉伸

    一.内边距 UIButton有三个属性,分别可以设置按钮以及内部子控件的内边距 1.contentEdgeInsets 如果是设置contentEdgeInsets, 会把UIImageView和UI ...

  3. 【转】设计模式(九)外观模式Facade(结构型)

    设计模式--外观模式Facade(结构型): 1. 概述 外观模式,我们通过外观的包装,使应用程序只能看到外观对象,而不会看到具体的细节对象,这样无疑会降低应用程序的复杂度,并且提高了程序的可维护性. ...

  4. 【转】HTML5新增元素兼容旧浏览器方法

    ref:http://www.jb51.net/html5/163906.html 问题:如何让IE8-兼容这些标签?(需要设计JS中的DOM) 代码如下: <span style=" ...

  5. hdu 2870(dp求最大子矩阵)

    题意:让你求的是由同一字母组成的最大子矩阵,w可以变成a或者b,x可以变成b或者c,y可以变成a或者c,z可以变成a或者b或者c. 分析:这是hdu 1506.hdu 1505的加强版,具体的分析看我 ...

  6. 算法学习 - 图的广度优先遍历(BFS) (C++)

    广度优先遍历 广度优先遍历是非经常见和普遍的一种图的遍历方法了,除了BFS还有DFS也就是深度优先遍历方法.我在我下一篇博客里面会写. 遍历过程 相信每一个看这篇博客的人,都能看懂邻接链表存储图. 不 ...

  7. JSP简单的练习-用户登记表

    <%@ page language="java" import="java.util.*" pageEncoding="gb2312" ...

  8. C/C++ 知识点---LIB和DLL的区别与使用(网摘)

    LIB和DLL的区别与使用 原文出处:[远风工作室] 共有两种库:一种是LIB包含了函数所在的DLL文件和文件中函数位置的信息(入口),代码由运行时加载在进程空间中的DLL提供,称为动态链接库dyna ...

  9. API.day01

    第1部分 JDK API 1.1 API(Application Programming Interface,应用接口程序):已经封装好可以直接调用的功能(Java中以类的形式封装) 经常使用的JDK ...

  10. 一个前端开发者换电脑的过程(git篇)

    一,安装git. 要安装git,首先得把它下载下来.去到git官网. 现在开始安装. 讲真,这些东西哪些要勾哪些不要勾我也不清楚,所以全部都按默认的来,一路next. 现在再打开vscode的终端,发 ...