zoukankan      html  css  js  c++  java
  • SPQuery ViewAttributes Sharepoint列表查询范围

    SPSite site=new SPSite(SPContext.Current.Web.Url);
                SPWeb web=site.OpenWeb();
                SPList splist=web.Lists["项目记录"];
                SPQuery query = new SPQuery();
                SPQuery queryDefault = new SPQuery();
                SPQuery queryFilesOnly = new SPQuery();
                SPQuery queryRecursive = new SPQuery();
                SPQuery queryRecursiveAll = new SPQuery();
                queryDefault.ViewAttributes = "Scope='Default'";
                queryFilesOnly.ViewAttributes = "Scope='FilesOnly'";
                queryRecursive.ViewAttributes = "Scope='Recursive'";
                queryRecursiveAll.ViewAttributes = "Scope='RecursiveAll'";
               // query.Query = "<Where><Eq><FieldRef Name='" + splist.Fields["项目名称"].InternalName + "'/><Value Type='Text'>" + this.DropDownList1.SelectedValue + "</Value></Eq></Where>";
                //query.RowLimit = 1;
                int i = 1;
                
                
    
                    SPListItemCollection listItems = splist.GetItems(query);
                    SPListItemCollection listItemsDefault = splist.GetItems(queryDefault);
                    SPListItemCollection listItemsFilesOnly = splist.GetItems(queryFilesOnly);
                    SPListItemCollection listItemsRecursive = splist.GetItems(queryRecursive);
                    SPListItemCollection listItemsRecursiveAll = splist.GetItems(queryRecursiveAll);

    sharepoint列表为【项目记录】

    此列表既包括文件夹又包括列表项,目录结构如下:

    【项目记录】下面包括3个东西:

    其中【2013】和【2012】为文件夹,【1】为列表记录

    2013下面包括如下内容:

    5个文件夹,这些文件夹下都无内容

    2012下面包括如下内容:

    2012下面就只有【01】文件夹,

    【01】文件夹下面内容如下:

    都是列表项,14项。

    那么总的文件夹数目:【2013】+【201301】+【201303】+【201304】+【201305】+【201312】+【2012】+[201201]=8项

    总的列表纯记录数:15项。

    从程序调试结果可以看到:

      queryDefault.ViewAttributes = "Scope='Default'";这个取出的范围为和没有赋值取出的范围一样的,3跳记录,都只是取出第1层的记录数,包括文件夹和列表记录
                queryFilesOnly.ViewAttributes = "Scope='FilesOnly'";这个取出的范围为第一层的列表记录数,为1条记录
                queryRecursive.ViewAttributes = "Scope='Recursive'";这个取出的范围是递归寻找所有层的纯列表记录数,为第一层的1+文件夹【201201】下的14条记录,合计为15条记录。
                queryRecursiveAll.ViewAttributes = "Scope='RecursiveAll'";这个是递归取出所有的文件夹和文件夹纯列表,合计为23条记录。

    没有只是取出文件夹列表的属性设置吗,要是有就更好。

  • 相关阅读:
    How to clean up BizTalk Message Box
    BizTalk: Database ‘BizTalkMsgBoxDb’ is full
    Install or Uninstall a Windows Service
    Distinguished Fields and Optional Elements
    Stay Hungry, Stay Foolish
    男子英文名大全,来历、释义
    Correlations in BizTalk 2004
    17.域环境解决方案
    18.windows痕迹清理
    Burpsuit手机抓包
  • 原文地址:https://www.cnblogs.com/oymx/p/3493807.html
Copyright © 2011-2022 走看看