Book Image

Mastering Apex Programming

By : Paul Battisson
5 (1)
Book Image

Mastering Apex Programming

5 (1)
By: Paul Battisson

Overview of this book

As applications built on the Salesforce platform are now a key part of many organizations, developers are shifting focus to Apex, Salesforce’s proprietary programming language. As a Salesforce developer, it is important to understand the range of tools at your disposal, how and when to use them, and best practices for working with Apex. Mastering Apex Programming will help you explore the advanced features of Apex programming and guide you in delivering robust solutions that scale. This book starts by taking you through common Apex mistakes, debugging, exception handling, and testing. You'll then discover different asynchronous Apex programming options and develop custom Apex REST web services. The book shows you how to define and utilize Batch Apex, Queueable Apex, and Scheduled Apex using common scenarios before teaching you how to define, publish, and consume platform events and RESTful endpoints with Apex. Finally, you'll learn how to profile and improve the performance of your Apex application, including architecture trade-offs. With code examples used to facilitate discussion throughout, by the end of the book, you'll have developed the skills needed to build robust and scalable applications in Apex.
Table of Contents (21 chapters)
1
Section 1 – Triggers, Testing, and Security
8
Section 2 – Asynchronous Apex and Apex REST
15
Section 3 – Apex Performance

Summary

In this chapter, we have seen how we can effectively utilize Batch Apex as a tool to enable us to make changes against large volumes of data or process work as and when resources are available.

We started the chapter by reviewing what Batch Apex is and the different common use cases for Batch Apex. Some of these use cases can also be achieved with other tools and so it is important that when you are reviewing Batch Apex as a potential tool, you compare it appropriately with other options. It is not a silver bullet to simply help you work with an increased set of governor limits.

Following this, we looked at the different ways in which we can define a Batch Apex class to meet these use cases and the difference between using a QueryLocator and an Iterable to define the scope of the job. As noted, it is most common to use a QueryLocator object as it allows the greatest amount of scale for data volumes.

We then looked at how we can invoke Batch Apex processes in both a...