Get started
Apex SOQL provides functional constructs for SOQL.
Examples
//SELECT Id FROM Account
List<Account> accounts = SOQL.of(Account.SObjectType).toList();
//SELECT Id, Name, Industry, Country FROM Account
List<Account> accounts = SOQL.of(Account.SObjectType)
   .with(new List<SObjectField>{
      Account.Id, Account.Name, Account.Industry, Account.Country
   }).toList();
Benefits
- Additional level of abstraction - The selector layer is an additional level of abstraction that gives you the possibility to control the execution of SOQL.
- Mocking - Selector classes give a possibility to mock return values in unit tests.- Mock external objects (__x) - External objects cannot be inserted in unit tests. You need to mock them.
- Mock custom metadata - Custom metadata cannot be inserted in unit tests unless the developer uses the Metadata API. Mock can be a solution.
 
- Control field-level security - The best practice is to execute SOQLs WITH USER_MODEto enforce field-level security and object permissions of the running user. The selector layer can applyWITH USER_MODEby default to all of the queries, so the developer does not need to care about it. Developers can also addWITH SYSTEM_MODEto all SOQLs from a specific selector.
- Control sharings rules - The selector allows to execute of different methods in the same class in different sharing modes.
- Avoid duplicates - Generic SQOLs like getById, andgetByRecordTypecan be stored in the selector class.
- Default configuration - The selector class can provide default SOQL configuration like default fields, FLS settings, and sharing rules.
- Mocking - The selector class has built in Mocking functionality that provides ability to dynamically return data in test execution
License notes
- For proper license management each repository should contain LICENSE file similar to this one.
- Each original class should contain copyright mark: Copyright (c) 2023 BeyondTheCloud.Dev