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条记录。
没有只是取出文件夹列表的属性设置吗,要是有就更好。