• SharePoint 2010 获取列表中所有数据(包括文件夹内)的方法


    转: http://blog.csdn.net/wangwenism/article/details/8751411

    SharePoint的列表能存储文件以及文件夹,用户使用的时候,经常会建几个分类文件夹,然后分别存放不同类型的文件,以方便查阅管理。

    当文件夹以及文件越来越多的时候,用户就会有搜索特定文档的要求,用户通常都不希望去每个文件夹分别查询,所以我们必须设计一个单独的查询模块去获取列表中包括每个文件夹里的所有数据。

    用sharepoint自带的搜索是一种解决方案,也可以利用SharePoint对象模型对整个列表进行查询。

    以下介绍2种查询方法。

    1. 如果是用SPDateSource查询的话,SPDateSource默认的数据查询范围是Default,即显示列表当前目录下的所有文件以及文件夹,并不包括文件夹里的文件,这个查询范围是个名为SPViewScope的枚举类型,详细解释如下图:

      Member name Description
      Default Show only the files and subfolders of a specific folder.
      Recursive Show all files of all folders.
      RecursiveAll Show all files and all subfolders of all folders.
      FilesOnly Show only the files of a specific folder.

    所以我们可以将范围值定义成Recursive 或 RecursiveAll 即可。如下:

    1. SPDataSource ds = currentListViewWebPart.DataSource as SPDataSource;  
    2. ...  
    3. ds.Scope = SPViewScope.Recursive;  


    2. 如果是用SPQuery查询的话,有个ViewAttributes属性可以设置范围,范围的默认值也是Default,枚举值和上面的相同,代码写法如下:

    1. private SPListItemCollection GetItems(SPList list)  
    2.         {  
    3.             SPQuery query = new SPQuery();  
    4.             query.ViewAttributes = "Scope="RecursiveAll"";  
    5.             SPListItemCollection itemCollection = list.GetItems(query);  
    6.             return itemCollection;  
    7.         }  


    如果想指定单独的文件夹进行查询,SPQuery有个folder属性,指定特定的文件夹名就可以了。

  • 相关阅读:
    MySQL索引管理及执行计划
    MySQL客户端工具及SQL讲解
    mysql数据类型
    mysq日志管理
    mysql连接管理及实例初始化配置
    mysql用户权限管理
    msyql5.6与mysql5.7安装区别
    mysql简介
    ASP.NET使用ImageMap控件
    ASP.NET Calendar(日历控件)
  • 原文地址:https://www.cnblogs.com/jackljf/p/3588850.html
Copyright © 2020-2023  润新知