Select to view content in your preferred language

How to perform multi-table Join using QueryDef

1970
6
Jump to solution
11-20-2020 07:00 AM
DHuantes
Regular Contributor

I have the following code that works fine:

await QueuedTask.Run(() =>
{
     using (Geodatabase l_myGDB = new Geodatabase(new 
     FileGeodatabaseConnectionPath(new Uri(<MyGeodatabase>))))
     {
        QueryDef queryDef = new QueryDef
        {
          Tables = "People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID",
          SubFields = "People.ObjectID,People.First_Name, People.Last_Name, People.City, State.State_Name",
        };

using (RowCursor l_rowCursor = l_laserGDB.Evaluate(queryDef,false))
{
    while(l_rowCursor.MoveNext())
    {
        //Grab all the data....
    }
}

 

But I can't seem to get the syntax correct to LEFT JOIN the previous resulting join with another table.  What I want to do is....

await QueuedTask.Run(() =>
{
     using (Geodatabase l_myGDB = new Geodatabase(new 
     FileGeodatabaseConnectionPath(new Uri(<MyGeodatabase>))))
     {
        QueryDef queryDef = new QueryDef
        {
          Tables = "((People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID) LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID)",
          SubFields = "People.ObjectID,People.First_Name, People.Last_Name, People.City, State.State_Name, People.FK_HOME_ID, Homes.Address",
        };

using (RowCursor l_rowCursor = l_laserGDB.Evaluate(queryDef,false))
{
    while(l_rowCursor.MoveNext())
    {
        //Grab all the data....
    }
}

These are not exactly my tables names but you get the gist.   I'm trying not to duplicate states so that's why the People table as a Foreign Key to the State table.  For the third table I want people to be able to own more than one home 

I suspect it's how the Tables Property is expected to be formatted but haven't been able to figure it out... as of yet.. Thought someone could point me in the right direction.  Documentation I found seems to indicate I should be able to query multiple tables in a single Query.  I know I can do this with any standard database outside of ArcGIS Pro just trying to figure out how to do it here.   Thanks.

 

0 Kudos
1 Solution

Accepted Solutions
DHuantes
Regular Contributor

@ChristopherKoenig and @KimberlySaballett   I updated to 2.7 and any of the following Tables strings work in QueryDef for the example now.  Thank you and thanks to the development team for fixing this.

 

QueryDef queryDef = new QueryDef
{
  // Option 1: Tables = "People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID",
  // Option 2: Tables = "(People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID) LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID",
  // Option 3:
  Tables = "((People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID) LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID)",
  SubFields = "People.OBJECTID,People.First_Name, People.Last_Name, People.City, States.Abbreviation, Homes.Address",
};

 

 

View solution in original post

0 Kudos
6 Replies
Aashis
by Esri Contributor
Esri Contributor

Hi @DHuantes, I am not able to reproduce the syntax error from the provided sample. Did you see any specific error message when this happened?

In order to investigate the error, I have created 3 tables with dummy data and run QueryDef as on example1 and example 2 and both of them gave me the results  -

  AashisLamsal1_0-1606160189766.pngAashisLamsal1_1-1606160200063.png

AashisLamsal1_2-1606160210881.png

 

 

 

 

 

 

Example: 1

AashisLamsal1_5-1606160454112.png

Example: 2

AashisLamsal1_3-1606160238321.png

Output:

AashisLamsal1_4-1606160305179.png

0 Kudos
DHuantes
Regular Contributor

Hmmm....  Not sure why I'm getting this error then....   I'm in the middle of another part of the code right now but took a quick look and didn't see any syntax issues.  I ended up doing multiple queries as workaround but if I can get this to work it would clean up the code.   Thanks... At least now I know it should be possible.  I'll try replicate the problem as you did independent of my Add-In  to see what's unique about my add-in.  

devenv_aWaAN5rt66.png

 

0 Kudos
KimberlySaballett
Esri Contributor

I was able to reproduce your error with the above solution and fix it by removing the parentheses in the SQL expression. SQL is executed from left to right so the parentheses here were unnecessary.

0 Kudos
ChristopherKoenig
Esri Contributor

Hi @DHuantes,

I have been working with your code from your post to see what I could find about the 'Invalid SQL' error. After further testing of this behavior I have found that as of version 2.7 of the ArcGIS Pro SDK for .NET parentheses can be used in nested SQL statements without issue.

0 Kudos
DHuantes
Regular Contributor

@ChristopherKoenig and @KimberlySaballett   I updated to 2.7 and any of the following Tables strings work in QueryDef for the example now.  Thank you and thanks to the development team for fixing this.

 

QueryDef queryDef = new QueryDef
{
  // Option 1: Tables = "People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID",
  // Option 2: Tables = "(People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID) LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID",
  // Option 3:
  Tables = "((People INNER JOIN States ON People.FK_STATE_ID = States.OBJECTID) LEFT JOIN Homes ON People.OBJECTID = Homes.FK_PEOPLE_ID)",
  SubFields = "People.OBJECTID,People.First_Name, People.Last_Name, People.City, States.Abbreviation, Homes.Address",
};

 

 

0 Kudos
PARTHASARATHIU
New Contributor

@ChristopherKoenig @KimberlySaballett @Aashis QueryDef mainQueryDef = new QueryDef
{
Tables = $"DD_PLAN_1_STUDENT_COUNT LEFT JOIN ({"SELECT DD_PLAN_1_STA_ENROLLMENT.SCHL_ATND AS SCHOOL, Sum( DD_PLAN_1_STA_ENROLLMENT.TOTAL_ENROLLMENT) AS TOTALENROLL, SUM(DD_PLAN_1_STA_ENROLLMENT.GPK+DD_PLAN_1_STA_ENROLLMENT.GK+DD_PLAN_1_STA_ENROLLMENT.G1+" +
"DD_PLAN_1_STA_ENROLLMENT.G2+DD_PLAN_1_STA_ENROLLMENT.G3+DD_PLAN_1_STA_ENROLLMENT.G4+DD_PLAN_1_STA_ENROLLMENT.G5+DD_PLAN_1_STA_ENROLLMENT.G6) AS [PK-6], SUM(DD_PLAN_1_STA_ENROLLMENT.GPK) AS GPK, SUM(DD_PLAN_1_STA_ENROLLMENT.GK) AS GK, SUM(DD_PLAN_1_STA_ENROLLMENT.G1) AS G1, SUM(DD_PLAN_1_STA_ENROLLMENT.G2) AS G2, " +
"SUM(DD_PLAN_1_STA_ENROLLMENT.G3) AS G3, SUM(DD_PLAN_1_STA_ENROLLMENT.G4) AS G4, SUM(DD_PLAN_1_STA_ENROLLMENT.G5) AS G5, SUM(DD_PLAN_1_STA_ENROLLMENT.G6) AS G6, SUM(DD_PLAN_1_STA_ENROLLMENT.G7) AS G7, SUM(DD_PLAN_1_STA_ENROLLMENT.G8) AS G8," +
" SUM(DD_PLAN_1_STA_ENROLLMENT.G9) AS G9, SUM(DD_PLAN_1_STA_ENROLLMENT.G10) AS G10, SUM(DD_PLAN_1_STA_ENROLLMENT.G11) AS G11, SUM(DD_PLAN_1_STA_ENROLLMENT.G12) AS G12 FROM DD_PLAN_1_STA_ENROLLMENT GROUP BY DD_PLAN_1_STA_ENROLLMENT.SCHL_ATND"}) AS DD_ENROLLMENT ON DD_PLAN_1_STUDENT_COUNT.SCHL_NAME = DD_ENROLLMENT.SCHOOL",
SubFields = "DD_PLAN_1_STUDENT_COUNT.SCHL_NAME AS SCHOOL, " +
"DD_PLAN_1_STUDENT_COUNT.GRD_RANGE AS GRADES_SERVED, " +
"DD_ENROLLMENT.TOTALENROLL + DD_PLAN_1_STUDENT_COUNT.TOTAL AS ENROLLMENT, " +
"DD_PLAN_1_STUDENT_COUNT.[RS], " +
"DD_PLAN_1_STUDENT_COUNT.[OD_UM], " +
"DD_ENROLLMENT.PK6, " +
"DD_ENROLLMENT.GPK, DD_ENROLLMENT.GK, " +
"DD_ENROLLMENT.G1, DD_ENROLLMENT.G2, " +
"DD_ENROLLMENT.G3, DD_ENROLLMENT.G4, DD_ENROLLMENT.G5, " +
"DD_ENROLLMENT.G6, DD_ENROLLMENT.G7, " +
"DD_ENROLLMENT.G8, DD_ENROLLMENT.G9, " +
"DD_ENROLLMENT.G10, DD_ENROLLMENT.G11, DD_ENROLLMENT.G12",
WhereClause = schoolClause
};

It throws errors: invalid SQL statement. How can I resolve this issue using ArcGIS Pro add-ins in WPF? 

0 Kudos