1. Create a custom field on the Account.
data:image/s3,"s3://crabby-images/a99f2/a99f2d269965fc05da15c7f1592700818d7eec44" alt=""
2. Create a Workflow Rule on the Opportunity Object.
data:image/s3,"s3://crabby-images/68c22/68c22ec81246f5bc77dd45a3cdfd2a434ffc0c9b" alt=""
3. Create a Field Update on Opportunity Object.
data:image/s3,"s3://crabby-images/bd99b/bd99b2b89c55b6e65ad863cdc348f4ba001cd8f6" alt=""
4. Create a Validation Rule on the Opportunity Object.
data:image/s3,"s3://crabby-images/5d3c1/5d3c1367e24ce696a75d58e745921e46360a832f" alt=""
Output:
data:image/s3,"s3://crabby-images/0d2e0/0d2e0c228937db5c61c3ab41c01623fcc1b0ef11" alt=""
For doing the same development using Apex Trigger, check the below
Sample Trigger:
trigger OpportunityTrigger on Opportunity ( before insert ) {
Set < Id > setAccountIds = new Set < Id >();
Map < Id, List < Opportunity > > mapAccIdNewOpptyList = new Map < Id, List < Opportunity > >();
Map < Id, List < Opportunity > > mapAccIdOldOpptyList = new Map < Id, List < Opportunity > >();
for ( Opportunity objOppty : trigger.new ) {
if ( String.isNotBlank( objOppty.AccountId ) ) {
setAccountIds.add( objOppty.AccountId );
if ( !mapAccIdNewOpptyList.containsKey( objOppty.AccountId ) )
mapAccIdNewOpptyList.put( objOppty.AccountId, new List < Opportunity > () );
mapAccIdNewOpptyList.get( objOppty.AccountId ).add( objOppty );
}
}
if ( setAccountIds.size() > 0 ) {
for ( Opportunity objOppty : [ SELECT Id, AccountId FROM Opportunity WHERE AccountId IN: setAccountIds AND CreatedDate = TODAY ] ) {
if ( !mapAccIdOldOpptyList.containsKey( objOppty.AccountId ) )
mapAccIdOldOpptyList.put( objOppty.AccountId, new List < Opportunity > () );
mapAccIdOldOpptyList.get( objOppty.AccountId ).add( objOppty );
}
for ( Opportunity objOppty : trigger.new ) {
if ( String.isNotBlank( objOppty.AccountId ) ) {
if ( mapAccIdOldOpptyList.containsKey( objOppty.AccountId ) )
objOppty.addError( 'Opportunity already added for this Account today' );
else if ( mapAccIdNewOpptyList.containsKey( objOppty.AccountId ) && mapAccIdNewOpptyList.get( objOppty.AccountId ).size() > 1 )
objOppty.addError( 'You cannot import multiple opportunities to the same account at the same day' );
}
}
}
}
To check multiple opportunities getting inserted at the same time for an account, use the below code and execute in Anonymous Window.
data:image/s3,"s3://crabby-images/3a0ec/3a0ec86e618ebed69534b871092c79f7b92baeea" alt=""
List < Opportunity > listOppty = new List < Opportunity >();
listOppty.add( new Opportunity( Name = 'Testing 1', StageName = 'Qualification', CloseDate = System.today(), AccountId = '0014x00000FE6CEAA1' ) );
listOppty.add( new Opportunity( Name = 'Testing 2', StageName = 'Qualification', CloseDate = System.today(), AccountId = '0014x00000FE6CEAA1' ) );
insert listOppty;
data:image/s3,"s3://crabby-images/4246c/4246ca148489b642ebd20be4569cf1b5d7b9b578" alt=""