Skip to main content

Step by Step SPQuery List joins


SharePoint 2010 Step by Step SPQuery List joins Using CAML

I am using the example following example lists
  1. CustomerCity List
  2. Customer

List Columns 
CustomerCity columns are:

Tilte
Single Line text

Customer columns are:

Title
Single Line text
City
Lookup type of CustomerCity

Dummy Data used

For CustomerCity
Title
City1     
City2     
City3

For Customer
Title
City
Customer1
City1
Customer2
City1
Customer3
City2
Customer4
City2
customer5
City2
Customer6  
<NULL>

Using the Join in SharePoint 2010 List Using SPQuery Class.
We need to set the three most important properties for that.
  1. Joins
  2. ProjectedFields
  3. ViewFields


SharePoint 2010 adds Join To CAML SPQuery.Joins
Types of joins
  1. Inner
  2. Left

Requested Lookup columns
Projections allow inclusion of fields joined lists
SPQeury.ProjectedFields

Joins: Each join is represented by a Join element child of the Joins element. Only inner and left outer joins are permitted. Moreover, the field in the primary list must be a Lookup type field that looks up to the field in the foreign list. There can be joins to multiple lists, multiple joins to the same list, and chains of joins. If a given list is the foreign list in more than one join, it must have distinct aliases assigned to it by the ListAliasattributes of the Join elements representing the joins.
 Note: Multiple Lines of text, Choice type columns are not supported in ProjectedFields.


private void button1_Click(object sender, EventArgs e)
        {
            string siteUrl = "http://home";
            SPWeb _web = new SPSite(siteUrl).OpenWeb();

   
            var items =_web.Lists["Customer"].GetItems(GetQuery());

            foreach (SPListItem item in items)
            {
                MessageBox.Show(string.Format("{0}----{1}", item["Title"], item["CityTitle"]));
            }
        }
        
        private SPQuery GetQuery()
        {
            SPQuery _query = new SPQuery();
            
            _query.Query = "";
            _query.Joins = @"<Join Type='INNER' ListAlias='City'>
                          <!--List Name: CustomerCity-->
                          <Eq>
                            <FieldRef Name='City' RefType='ID' />
                            <FieldRef List='City' Name='ID' />
                          </Eq>
                        </Join>";

            _query.ProjectedFields = @"<Field Name='CityTitle' Type='Lookup' List='City' ShowField='Title' />
                                    <Field Name='CityContentTypeId' Type='Lookup' List='City' ShowField='ContentTypeId' />";

            _query.ViewFields = @" <FieldRef Name='Title' />
                                     <FieldRef Name='CityTitle' />";

            return _query;
        }

The above “Query” property of the SPQuery class I left blank you can enter the condition according to your requirement.

Comments

Popular posts from this blog

SharePoint RPC Protocols Examples Using OWSSVR.DLL

What is SharePoint RPC Protocols? Part 1 This reference includes information about the methods and usage of SharePoint Foundation Remote Procedure Call (RPC) protocol. This protocol can be used in Win32-based applications or in ASPX applications to make HTTP POST requests to the server. Methods in this protocol that do not modify the contents of the database can also be used in URL protocol to make HTTP GET requests. Definition taken from http://msdn.microsoft.com/en-us/library/ms448359.aspx You will find the OWSSVR.DLL in SharePoint 2010 Server Physical Path: C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\14\ISAPI and MOSS C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\12\ISAPI OWSSVR.DLL List of commands DialogView  Display ExportList GetProjSchema GetUsageBlob HitCounter RenderView To read more about the OWSSVR.DLL command Please read the URL Protocol from Microsoft Blog having a URL http://msdn.microsoft.com/en...

SharePoint 2013 CTX variable and its function part 1

In this post going to show you some of the useful Utility Functions that might be useful for you while working with search display template. I used most of the functions MSDN Link: https://msdn.microsoft.com/EN-US/library/office/dn768285.aspx CTX Function Part 2   CTX Function Part 3 CTX: In Display template CTX variable is responsible for returning the all the managed properties and other DOM elements. Utility Functions String Functions: For checking Null, Undefined & empty values  Srch.U.w(str): Indicates whether the given string is null, undefined, or empty. $isNull(str): Checking for Null Srch.U.n(str): Indicates whether the given object is null or undefined. $isEmptyString(str) : Checking for an empty string Srch.U.e(str): Indicates whether the string is null or empty. Array Functions: Split & other array related operations Srch.U.getArray(property): Splits the string into an array of strings using the semi colon (";") as a s...

Send Email using SharePoint Rest API

We have a requirement to send email vai SharePoint Rest API. We dig and find the below solution to send email using SharePoint API. Point Must be remember End point " /_api/SP.Utilities.Utility.SendEmail " end point to send email.  In JSON __metadata we used the type " SP.Utilities.EmailProperties ". The User / Group must have a read permission for particular site. where we placed this site code. JS Dependency  JQuery Code URL:  https://gist.github.com/BasantPandey/05189832546f2c6cc0bd008fcfec3264#file-sharepointsendemail-js Code  var Email = function (){ // Email Either email groupname or email address var from = ' abc.yahoo.com ' , to = ' abc.yahoo.com ' , cc = ' abc.yahoo.com ' , subject = ' My Email Subject ' ; this . options = this . options || {}; this . options [ ' fromEmail ' ] = this . options [ ' fromEmail ' ] || {}; this . options [ ' toEmail ...