Salesforce Query to Check the Existing Contact with Account id - salesforce

I already have contact by using Accountid, so before creating the new contact I want to verify the existing contact with email and id, can you please help me with this salesforce query to check if the Contact already exist with Contact Email and AccountId?
I already tried using the below query but it was throwing exceptions:
SELECT Id, Name , email
FROM Contact
WHERE email='XXX#Email.com'
AND Id IN (SELECT ContactId
FROM AccountContactRelation
WHERE AccountId = 'XXXX')
Got the below error:
INVALID_TYPE: and Id IN (SELECT ContactId FROM AccountContactRelation
WHERE AccountId
^
ERROR at Row:1:Column:121 sObject type 'AccountContactRelation' is not
supported. If you are attempting to use a custom object, be sure to
append the '__c' after the entity name. Please reference your WSDL or
the describe call for the appropriate names.
Can you please share the correct Salesforce Query ?

The below Query worked like charm :)
SELECT Id, Name , email
FROM Contact
WHERE email='XXXXXXXXX#XXX.com'
AND AccountId='YYYYY#yyy.com'

Related

__r.Name from Account is empty

In APEX class we have SOQL:
Case carrierList= [SELECT Id, CaseNumber, Current_Quoted_By_Carrier__c, Current_Quoted_By_Carrier__r.Name, Quoted_By_Carrier__c, Quoted_By_Carrier__r.Name FROM Case WHERE Id = :con.Id];
When we run SOQL in Workbench or Developer Console for specific recordId the Name is populated, but in APEX SOQL returns record Id, but no Name (DEBUG|Quoted by Carrier Name = null).
Case.Quoted_By_Carrier__c is a lookup on Account.
Check to make sure the profile has access to the account record and that the profile has read permissions on the account name field.

Get Contact Emails of Currently Active Account as List

Given: A Salesforce user is viewing an account page.
Desired Output: All Emails of Contacts related to the Account currently viewed as a List object.
My code:
SELECT Email FROM Contact WHERE Id IN (SELECT ContactId FROM AccountContactRelation WHERE AccountId = ApexPages.CurrentPage.getParameters().get('id'))
This does not retrieve any results. When using a fixed number instead of ApexPages.CurrentPage.getParameters().get('id'), the Emails are correctly returned.
I'm sort of new to Apex. Could anyone point out what I am doing wrong?
To achieve the desired output you need to use SOQL variable injection.
You can do this by creating a variable first and then referencing the variable inside the SOQL using : and the variable name:
String theAccountId = ApexPages.CurrentPage.getParameters().get('id');
List<Contact> theContacts = [SELECT Email FROM Contact WHERE Id IN (SELECT ContactId FROM AccountContactRelation WHERE AccountId = :theAccountId)];
You can use a static query with a bind variable to retrieve the correct results.
Additionally, the Contact object contains an AccountId field of its own. Therefore, depending on your setup, you may be able to eliminate your subquery. You may also want to filter out Email fields that are empty, since Email is not a required field.
The complete result could look something like this:
String accountId = ApexPages.CurrentPage.getParameters().get('id');
List<Contact> accountContactsEmailList = [
SELECT
Email
FROM
Contact
WHERE
Email != ''
AND AccountId = :accountId
];
for (Contact contact : accountContactsEmailList) {
System.debug(contact.Email);
}

Salesforce SOQL query to retrieve related accounts for an contact

I would like to retrieve the related account for an contact resource from saleforce API. I have tried the below query to retrieve account which has contact Id. But not able to get my requirement.
SELECT+Id,Name+from+Contact+where+Id+IN+(SELECT+AccountId+FROM+Contact+where+Email='xxx#gmail.com')
Anyone , please help.
You are actually trying to correlate Id from Contact object and Id from Account object. You can use the relations :
select account.name, account.id from contact where email='xxx#gmail.com'
You are trying to retrieve Account for Contact. You have Email id based on you want Account details.
If you want to Account id then use AccountID field also in your Query:
Your query will like this:
List<Contact> contactList = [Select id, name, AccountID
from contact where Email = 'test#gmail.com'];
for(Contact con : contactList) {
System.debug('Account id : ' + con.AccountID);
}

Relating Solutions to Accounts in Salesforce

Hi I am new to Salesforce SOQL. I am trying to relate a solution to the accounts but can't get it working. I have created a query but calling from API and executing following query returns me a 'Case' object
SELECT case.account.name
FROM case
WHERE id IN (
SELECT CaseId
FROM CaseSolution
WHERE SolutionId ='XXXXXXX'
)
What about querying the CaseSolution object and then Account Name details from the Case:
SELECT Case.Account.Name FROM CaseSolution WHERE SolutionId = 'XXXXXX' GROUP BY Case.Account.Name

Soql query to get all related contacts of an account in an opportunity

i have SOQL query which queries for some records based on a where condition.
select id, name,account.name ... <other fields> from opportunity where eventname__c='Test Event'
i also need to get the related contact details for the account in the opportunity. ie i need to add the email ids of contact who all are part of the account in the opportunity.
For each opportunity, i need to get all the contacts emailids who are associated with the account in opportunity.
I cant really figure out how to approach this.
referring the documentation i can get the contact info of a account using the query
SELECT Name,
(
SELECT LastName
FROM Contacts
)
FROM Account
How can i use this along with opportunity?
Thanks
The problem is that you are trying to traverse up from opportunity to its parent (account) and then back down to the children (contacts).
I think you will have to do it in two stages, e.g. roughly like:
id[] accountids = new id[]{};
for (opportunity opp : [select accountid from opportunity where eventname__c='Test Event'])
{
accountids.add (opp.accountid);
}
account[] acclist = [select name, (select email from contacts) from account where id in :accountIds];

Resources