I've used SOQL to successfully build a relationship between my main object and child objects through a junction object. Each of those children has children, so I want to use the SOQL relationship to replicate a table (which works) and a second SOQL relationship to replicate the grandchildren as rows. However, only the same grandchild record is replicated in the tables.
So it should be Table A has row a and Table B has row b, but what I have is Table A row a and Table B row a.
Does that make sense? Any guidance is appreciated!
Hey Tim McIntire,
You're on the right track but the way table and row replication work in SOQL Relationships is a little different than our basic Relationships.
You need to nest the grand child query in your main query.
SELECT Id, Name, (SELECT Id, Phone FROM Contacts) FROM Account
The above query would replicate Tables for Accounts and Rows for Contacts. If there are multiple grand children you can continue to nest queries within the query. The field tagger will automatically recognize this and add both objects into the tagger for you.
Example of multiple grand child objects:
SELECT Id, Name, (SELECT Id, Phone FROM Contacts), (SELECT Id, Name FROM Opportunities) FROM Account
I hope that helps.
UPDATED: Please keep in mind you need to use the child object relationship name on inner queries. So for example to find the Child Object Relationship name you can navigate to the Opportunity object in Setup find the field that looks up to the Account and grab the Child Object Relationship name from there.
(Click on the image to enlarge)
I'm so close I can taste it! I'm struggling with the syntax for using the child relationship name in the inner query. I feel like I need a "__r" somewhere...?
(SELECT AcctSeed__Amount__c FROM Project_Account_Payable_Lines)