- Apex - Deployment
- Apex - Testing
- Apex - Debugging
- Apex - Batch Processing
- Apex - Governer Limits
- Apex - Trigger Design Patterns
- Apex - Triggers
- Apex - Invoking
- Apex - Security
- Apex - SOQL
- Apex - SOSL
- Apex - Database Methods
- Apex - DML
- Apex - Interfaces
- Apex - Objects
- Apex - Methods
- Apex - Classes
- Apex - Collections
- Apex - Loops
- Apex - Decision Making
- Apex - Constants
- Apex - Arrays
- Apex - Strings
- Apex - Variables
- Apex - Data Types
- Apex - Example
- Apex - Environment
- Apex - Overview
- Apex - Home
Apex Useful Resources
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
Apex - Overview
What is Apex?
Apex is a proprietary language developed by the Salesforce.com. As per the official definition, Apex is a strongly typed, object-oriented programming language that allows developers to execute the flow and transaction control statements on the Force.com platform server in conjunction with calls to the Force.com API.
It has a Java-pke syntax and acts pke database stored procedures. It enables the developers to add business logic to most system events, including button cpcks, related record updates, and Visualforce pages.Apex code can be initiated by Web service requests and from triggers on objects. Apex is included in Performance Edition, Unpmited Edition, Enterprise Edition, and Developer Edition.
Features of Apex as a Language
Let us now discuss the features of Apex as a Language −
Integrated
Apex has built in support for DML operations pke INSERT, UPDATE, DELETE and also DML Exception handpng. It has support for inpne SOQL and SOSL query handpng which returns the set of sObject records. We will study the sObject, SOQL, SOSL in detail in future chapters.
Java pke syntax and easy to use
Apex is easy to use as it uses the syntax pke Java. For example, variable declaration, loop syntax and conditional statements.
Strongly Integrated With Data
Apex is data focused and designed to execute multiple queries and DML statements together. It issues multiple transaction statements on Database.
Strongly Typed
Apex is a strongly typed language. It uses direct reference to schema objects pke sObject and any invapd reference quickly fails if it is deleted or if is of wrong data type.
Multitenant Environment
Apex runs in a multitenant environment. Consequently, the Apex runtime engine is designed to guard closely against runaway code, preventing it from monopopzing shared resources. Any code that violates pmits fails with easy-to-understand error messages.
Upgrades Automatically
Apex is upgraded as part of Salesforce releases. We don t have to upgrade it manually.
Easy Testing
Apex provides built-in support for unit test creation and execution, including test results that indicate how much code is covered, and which parts of your code can be more efficient.
When Should Developer Choose Apex?
Apex should be used when we are not able to implement the complex business functionapty using the pre-built and existing out of the box functionapties. Below are the cases where we need to use apex over Salesforce configuration.
Apex Apppcations
We can use Apex when we want to −
Create Web services with integrating other systems.
Create email services for email blast or email setup.
Perform complex vapdation over multiple objects at the same time and also custom vapdation implementation.
Create complex business processes that are not supported by existing workflow functionapty or flows.
Create custom transactional logic (logic that occurs over the entire transaction, not just with a single record or object) pke using the Database methods for updating the records.
Perform some logic when a record is modified or modify the related object s record when there is some event which has caused the trigger to fire.
Working Structure of Apex
As shown in the diagram below (Reference: Salesforce Developer Documentation), Apex runs entirely on demand Force.com Platform
Flow of Actions
There are two sequence of actions when the developer saves the code and when an end user performs some action which invokes the Apex code as shown below −
Developer Action
When a developer writes and saves Apex code to the platform, the platform apppcation server first compiles the code into a set of instructions that can be understood by the Apex runtime interpreter, and then saves those instructions as metadata.
End User Action
When an end-user triggers the execution of Apex, by cpcking a button or accessing a Visualforce page, the platform apppcation server retrieves the compiled instructions from the metadata and sends them through the runtime interpreter before returning the result. The end-user observes no differences in execution time as compared to the standard apppcation platform request.
Since Apex is the proprietary language of Salesforce.com, it does not support some features which a general programming language does. Following are a few features which Apex does not support −
It cannot show the elements in User Interface.
You cannot change the standard SFDC provided functionapty and also it is not possible to prevent the standard functionapty execution.
Creating multiple threads is also not possible as we can do it in other languages.
Understanding the Apex Syntax
Apex code typically contains many things that we might be famipar with from other programming languages.
Variable Declaration
As strongly typed language, you must declare every variable with data type in Apex. As seen in the code below (screenshot below), lstAcc is declared with data type as List of Accounts.
SOQL Query
This will be used to fetch the data from Salesforce database. The query shown in screenshot below is fetching data from Account object.
Loop Statement
This loop statement is used for iterating over a pst or iterating over a piece of code for a specified number of times. In the code shown in the screenshot below, iteration will be same as the number of records we have.
Flow Control Statement
The If statement is used for flow control in this code. Based on certain condition, it is decided whether to go for execution or to stop the execution of the particular piece of code. For example, in the code shown below, it is checking whether the pst is empty or it contains records.
DML Statement
Performs the records insert, update, upsert, delete operation on the records in database. For example, the code given below helps in updating Accounts with new field value.
Following is an example of how an Apex code snippet will look pke. We are going to study all these Apex programming concepts further in this tutorial.
Advertisements