You need to sign in to do that
Don't have an account?
mikefitz
SOQL Query Outer Join Contacts and users
I am trying build an outer join to display a list of contacts showing if they have a related portal user records or not.
I know you can get a list of related contacts from the user object but is it possible to go from contacts to user?
I know this works...Select u.isactive, u.Contact.name From User u but what about Select name, c.user.isactive From Contact c?
Any thoughts how I can outer join these two tables and display one list?
Thanks
This might be of use to you.
http://wiki.developerforce.com/index.php/A_Deeper_look_at_SOQL_and_Relationship_Queries_on_Force.com
Thanks for the suggestion but I am familar with that.
I can't use a nested SOQL statement or traverse across objects because there is no lookup or m/d relationship from the contact to the user object even though the user record has the contactid on it.
It would be a simple outer join in SQL.
Additional thoughts?
As I review it more, I am seeing what you are saying. I am not seeing a way to query. I am thinking you may need to do this programatically.
1. Query Contact Table
2. Query User Table
3. Loop through Contacts and see if contact ID exists in User Table.
Certainly not ideal and hopefully somebody can reply with a better solution.
SOQL supports both parent-to-child and child-to-parent query, Since User object is parent of contact object,
You can write query like given below:
list<Contact> con=[Select id, lastName, firstName, OwnerId, Owner.Country, owner.isActive from Contact];
Pradeep, thanks for the feedback.
I understand what you are saying but I'm trying to get the associated portal user not the owner. The contact owner has a valid relationship that you can traverse. I am trying to get a full list of contacts with a boolean field displaying if they are a portal user or not. Any thoughts?
Example of my list
NAME | Portal User
John Doe X
Jane Dow
Barry White
Jerry Maguire X
Billy Tubbs X
You can't go from Contacts to User. You'll need to query the User object and then write some code to determine if a Contact is a portal user. For e.g.
List<Contact> listOfContacts = however you're getting your list of Contacts;
List<User> portalUsers = [select contactId from User where contactId in (select id from Contact where id in :listOfContacts)];
Set<Id> contactIds = new Set<Id> ();
for (User u : portalUsers)
{
contactIds.add(u.contactId);
}
for (Contact c : listOfContacts)
{
if (contactIds.contains(c.Id);
{
//You know if that this Contact has a Portal User. Perform any neccessary business logic here
}
}
Hope this helps...
Thanks for the feedback.
I think you are getting closer to what I am looking for but the only thing I'm trying to do is to create a list to display in a vf page.
I am redesigning the contact page and trying to display one list of contacts showing if they are a portal user or not instead of two (one for contacts and one for portal users)
I think a good way to produce your list is as follows:
SELECT
IsPortalEnabled,
IsActive,
Id,
CommunityNickname
WHERE contactId IN (SELECT id FROM Contact)
The only want to do this is using a wrapper class and presenting it within a visualforce page.
Here is a basic example. https://developer.salesforce.com/page/Wrapper_Class
Cheers and good luck.
Another way of getting this information.