• 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条记录。

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

  • 相关阅读:
    J
    I题
    H
    G
    F题
    E题
    D题
    C题
    B题
    A题
  • 原文地址:https://www.cnblogs.com/oymx/p/3493807.html
Copyright © 2020-2023  润新知