welcome to XRM blog

Keep in touch with latest CRM/ERP articles

To remain competitive your organisation must be efficient across the business process spectrum. To do so you need to take sound decisions based on a balance between the cost and risk. To do so you will be heavily dependent on your content management in itself needs...

image
Blog

Best Practices for Writing Apex Code

By Vikas Sain on 6/5/2025

Apex is a powerful programming language used to customize Salesforce applications. Writing efficient and scalable Apex code is crucial for maintaining performance and ensuring future scalability. Below are some best practices to follow when writing Apex code. 

1. Follow Governor Limits 

Why? Salesforce enforces governor limits to ensure shared resources are efficiently used. 

Best Practices: 

1. Optimize SOQL queries by using selective filters. 

2. Avoid using DML statements inside loops. 

3. Use bulk processing techniques. 

2. Use Bulk Processing 

Why? Apex should be written to handle large datasets efficiently. 

Best Practices: 

1. Use collections (Lists, Sets, Maps) to process records in bulk. 

2. Use FOR EACH loops instead of single record processing. 

3. Implement batch Apex for processing large data volumes. 

3. Avoid SOQL and DML in Loops 

Why? Running SOQL queries or DML operations within loops can lead to performance issues and hitting governor limits. 

Best Practices: 

1. Query records before the loop and store them in a collection. 

2. Perform bulk DML operations outside the loop. 

4. Use Custom Settings and Custom Metadata 

Why? Hardcoding values in Apex code is a bad practice. 

Best Practices: 

1. Store configurable values in Custom Settings or Custom Metadata Types. 

2. Implement Exception Handling 

5. Use them dynamically in Apex to enhance maintainability. 

Why? Proper error handling ensures a better user experience and easier debugging. 

Best Practices: 

1. Use try-catch blocks to handle exceptions. 

2. Log errors using a custom logging mechanism. 

3. Provide meaningful error messages. 

  1. Use Asynchronous Processing When Necessary 

Why? For time-consuming operations, consider asynchronous methods. 

Best Practices: 

1. Use Future Methods for simple asynchronous execution. 

2. Use Queueable Apex for chaining jobs. 

3. Use Batch Apex for processing large records efficiently. 

4. Use Scheduled Apex for executing jobs at specific times. 

  1. Use Security Best Practices 

Why? To ensure data security and compliance. 

Best Practices: 

1. Enforce field-level and object-level security using WITH SECURITY_ENFORCED in SOQL queries. 

2. Use isAccessible(), isUpdateable(), and isDeletable() methods. 

3. Avoid hardcoding user IDs and profile names. 

  1. Write Test Classes with High Coverage 

Why? Salesforce requires at least 75% code coverage for deployment. 

Best Practices: 

1. Use @isTest annotation. 

2. Create test data using Test.loadData() or Test.createData(). 

3. Cover positive, negative, and bulk scenarios. 

4. Use Test.startTest() and Test.stopTest() to handle governor limits. 

  1. Optimize SOQL Queries 

Why? Inefficient SOQL queries can slow down performance. 

Best Practices: 

1. Use indexed fields for selective queries. 

2. Avoid using SELECT *; instead, query only required fields. 

3. Use LIMIT and ORDER BY when necessary. 

  1. Follow Apex Design Patterns 

Why? Using design patterns improves code maintainability and reusability. 

Best Practices: 

1. Singleton Pattern for reusing objects. 

2. Repository Pattern for managing database interactions. 

3. Factory Pattern for creating test data efficiently. 

#Apex
#BestPractices
#BulkProcessing
#CodingStandards
#DesignPattern
#DML
#ExceptionHandling
#GovernorLimits
#Salesforce
#Security
#SOQL
#TestClasses
Author
Blog Calendar
Blog Calendar List
2025 Jun  5  2
2025 May  45  8
2025 Apr  34  6
2025 Mar  53  7
2025 Feb  41  6
2024 Nov  11  1
2024 Aug  7  1
2024 Apr  58  4
2024 Mar  155  4
2024 Feb  414  3
2024 Jan  33  7
2023 Dec  39  6
2023 Nov  548  5
2023 Oct  756  12
2023 Sep  1772  9
2023 Aug  544  6
2023 Jul  47  6
2023 Jun  26  4
2023 May  44  5
2023 Apr  81  5
2023 Mar  222  6
2023 Feb  171  5
2023 Jan  80  4
2022 Dec  96  7
2022 Nov  293  2
2022 Sep  13  1
2022 Aug  32  2
2022 Jun  11  2
2022 May  6  2
2022 Apr  12  2
2022 Mar  2  1
2022 Feb  2  1
2022 Jan  1  1
2021 Dec  4  1
2021 Nov  2  1
2021 Oct  2  1
2021 Sep  14  1
2021 Aug  49  5
2021 Jul  51  4
2021 Jun  1843  5
2021 May  42  3
2021 Apr  2255  3
2021 Mar  215  5
2021 Feb  2752  7
2021 Jan  4168  9
2020 Dec  583  7
2020 Sep  80  3
2020 Aug  789  3
2020 Jul  139  1
2020 Jun  98  3
2020 Apr  103  3
2020 Mar  19  2
2020 Feb  34  5
2020 Jan  48  7
2019 Dec  17  4
2019 Nov  40  1
2019 Jan  23  2
2018 Dec  139  4
2018 Nov  68  3
2018 Oct  18  3
2018 Sep  1267  11
2018 Aug  7  2
2018 Jun  20  1
2018 Jan  72  2
2017 Sep  590  5
2017 Aug  17  1
2017 Jul  17  2
2017 Jun  65  2
2017 May  21  1
2017 Apr  39  2
2017 Mar  139  4
2017 Feb  844  4
2016 Dec  208  3
2016 Nov  1044  8
2016 Oct  340  10
2016 Sep  805  6
2016 Aug  39  1
2016 Jun  1893  6
2016 May  114  3
2016 Jan  72  2
2015 Dec  738  6
2015 Nov  4  1
2015 Oct  13  1
2015 Sep  1471  6
2015 Aug  14  1
2015 Jul  129  2
2015 Jun  11  1
2015 May  20  1
2015 Apr  30  3
2015 Mar  80  3
2015 Jan  5350  4
2014 Dec  18  1
2014 Nov  2260  4
2014 Oct  69  1
2014 Sep  107  2
2014 Aug  5334  1
2014 Jul  49  2
2014 Apr  2599  12
2014 Mar  307  17
2014 Feb  223  6
2014 Jan  1510  16
2013 Dec  21  2
2013 Nov  695  2
2013 Oct  256  3
2013 Sep  13  1
2013 Aug  40  3
2013 Jul  214  1
2013 Apr  62  6
2013 Mar  2395  10
2013 Feb  131  3
2013 Jan  352  2
2012 Nov  62  2
2012 Oct  519  10
Tag Cloud
Interested in our services? Still not sure about project details? get a quote