设为首页 收藏本站
查看: 1115|回复: 0

[经验分享] SharePoint列表,多条件查询

[复制链接]

尚未签到

发表于 2015-9-27 06:50:49 | 显示全部楼层 |阅读模式
  
  下面是一个带有两个左外部联接的 Joins 元素的示例。CustomerName 是 Orders 列表上的查阅字段。它查阅 Customers 列表的 ID 字段。而 Customer 列表具有一个 CityName 字段,该字段又是 Cities 列表的查阅字段。第一个 Join 元素将"customers"指派为 Customers 列表的别名。Eq 元素的子元素定义使用构成查阅关系的相同源和目标字段的联接。第二个 Join 元素将"customerCities"指派为 Cities 列表的别名。它定义与 Customer 和 Cities 列表之间的现有查阅关系平行的联接。
  别名对列表而言非常重要,因为同一列表上可能存在多个联接,需要使用不同的别名区分这些联接。例如,除了从 Orders 到 Customer 以及从 Customer 到 Cities 的联接外,可能还存在从 Orders 到 Suppliers 以及从 Suppliers 到 Cities 的联接。在最后一种联接中,将为 Cities 列表指派一个不同于从 Customer 到 Cities 联接中所用别名的别名(如"supplierCities")。








复制




<Joins>
<Join Type=’LEFT’ ListAlias=’customers’>
<Eq>
<FieldRef Name=’CustomerName’ RefType=’Id’ />
<FieldRef List=’customers’ Name=’ID’ />
</Eq>
</Join>
<Join Type=’LEFT’ ListAlias=’customerCities’>
<Eq>
<FieldRef List=’customers’ Name=’CityName’ RefType=’Id’ />
<FieldRef List=’customerCities’ Name=’ID’ />
</Eq>
</Join>
</Joins>




using (SPSite site=new SPSite(SPContext.Current.Web.Url))
            {
                using (SPWeb web=site.OpenWeb(SPContext.Current.Web.ServerRelativeUrl))
                {
                   SPQuery query = new SPQuery();
                   //Joins属性,这里有INNER和LEFT两种方式连接,均可查询,而且支持多表连接;
                   query.Joins = @"<Join Type='INNER' ListAlias='City'>" +
                                       "<Eq>" +
                                           "<FieldRef Name='Location' RefType='Id'/>" +//  RefType='Id'
                                           "<FieldRef List='City' Name='ID'/>" +//  ID
                                       "</Eq>" +
                                   "</Join>";
                   //设置关联的查阅项字段,多表连接支持能查询  文本字段。。。
                   query.ProjectedFields = "<Field Name='CustomCityIDs' Type='Lookup' " +  、//CustomCityIDs是给列重命名,避免和其他列重名;只能写成查阅项字段
                                                   "List='City' ShowField='CityID'/>"+
                                                   "<Field Name='Mark' Type='Lookup' " +//
                                                   "List='City' ShowField='Mark'/>";
                   //设置需要显示的字段
                   query.ViewFields = "<FieldRef Name='Title'/>" +
                                       "<FieldRef Name='Location'/>" +
                                       "<FieldRef Name='Mark'/>" +
                                       "<FieldRef Name='CustomCityID'/>";
                   SPList list = web.Lists.TryGetList("Address");
                   SPListItemCollection itemcoll = list.GetItems(query);
                   foreach (SPListItem item in itemcoll)
                   {
                       //SPFieldLookupValue Location = new SPFieldLookupValue(item["Location"].ToString());
                       //SPFieldLookupValue CustomCityID = new SPFieldLookupValue(item["CustomCityID"].ToString());
                       //Console.WriteLine("ID:" + item.ID.ToString() + " Title:" + item["Title"].ToString() + " Location:" + Location.LookupValue + " CustomCityID:" + CustomCityID.LookupValue);
                   }
                }
            }
            });

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-119215-1-1.html 上篇帖子: JS判断SharePoint页面编辑状态 下篇帖子: SharePoint Server 2007 简体中文下载
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表