sharepoint2010 list联合查询--(未整理)

本文介绍了在SharePoint 2010中使用SPQuery和SPSiteDataQuery进行列表联合查询的方法。通过SQL-like语法连接tableA和tableB,根据特定条件筛选数据,例如Name或CityName。
摘要由CSDN通过智能技术生成
 遇到多个list联合查询的问题,where条件来自多个表
遇到多个list联合查询的问题,需要用CAML做到类似于SQL中的:

 select A.*,A.CityID,B.CityNAME from tableA A left join tableB B on A.CityID=B.ID where tableA .Name=xxx or tableB.CityName=xxx  or....

先说SPQuery 和SPSiteDataQuery的区别

 MOSS 关于SPQuery 的用法,是关于列表的查询

 SPWeb web = (new SPSite(" http://moss/sites/hello)).OpenWeb (); 
SPList list = web.Lists["test"]; 
SPQuery query = new SPQuery(); 
query.Query = " 4 "; 
SPListItemCollection items = list.GetItems(query); 
foreach(SPListItem item in items) 
Console.WriteLine(item.DisplayName); 
    SPSiteDataQuery的是查询整个Site的范围比SPQuery。
SPWeb web = (new SPSite(" http://moss/sites/hello)).OpenWeb (); 
SPSiteDataQuery query = new SPSiteDataQuery(); 
query.Query = " 4 "; 
query.Lists = " 
"; 
query.Webs = " "; 
query.ViewFields = " 
"; 
DataTable dt = web.GetSiteData(query); 
Console.WriteLine(dt.Rows.Count); 

SPSiteDataQuery siteQuery = new SPSiteDataQuery();
                                 siteQuery.Webs = "<Webs Scope=\"SiteCollection\" />";
                                 siteQuery.Lists = string.Format("<Lists><List ID='{0}' /><List ID='{1}' /&g
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值