R1D38 SOQL and SOSL Queries in Apex

| programming | salesforce | databases |

I’m working through the Apex Basics & Database module on Trailhead.

I learned about using built in sObjects and also about making custom sObjects. Next I learned about how to use DML in order to manipulate records within the system. After getting the basics down we dove into SOQL.

SOQL

SOQL is shot for Salesforce Object Query Language. If you are familiar with SQL you will feel right at home. SOQL makes querying data very simple. One pretty poweful feature is the ability to run inline queries and return the results to a variable. In pretty much every other language you would need to create a cursor and iterate over the results in order to read the values from a database. In SOQL you simply assing the results to an array.
# Python Example 

conn = sqlite3.connect(’example.db’) c = conn.cursor() results = c.execute(“SELECT Name, Phone FROM Accounts”)

for row in results: print row

# SOQL Example 

Accounts[] accts = [SELECT Name, Phone FROM Account];

I think this bit trips up a lot of new programmers so it is great to see how SOQL makes it easy.

One thing worth noting is that you canno use  the handy “SELECT *” that is found in SQL.

Unlike other SQL languages, you can’t specify * for all fields. You must specify every field you want to get explicitly. If you try to access a field you haven’t specified in the SELECT clause, you’ll get an error because the field hasn’t been retrieved.
The built in developer console in Salesforce makes it very easy to run queries and inspect your objects without writing any additional code.

Cool things about SOQL:

SOSL

SOSL is short for Salesforce Object Search Language and it allows you to do robust full text search on records similar to Apache Lucene. The main difference is that it allows you to search accross multiple objects instead of just a single one.
FIND 'SearchQuery' [IN SearchGroup] [RETURNING ObjectsAndFields]
In order to pass a variable into the search query, you use the colon symbol.
public class MultiSearch {

    public static List> searchAll (String searchTerm) {
        List> searchList = [FIND :searchTerm IN ALL FIELDS RETURNING Account(Name),Contact(FirstName,LastName)];
        return searchList;
    }
}

Thank you for reading! Share your thoughts with me on mastodon or via email.

Check out some more stuff to read down below.

Most popular posts this month

Recent Favorite Blog Posts

This is a collection of the last 8 posts that I bookmarked.

Articles from blogs I follow around the net

Supermicro NVIDIA GB200 NVL72 System at Computex 2024

We checked out the Supermicro NVIDIA GB200 NVL72 rack at Computex 2024. This is a prime example of why power is becoming such a big deal The post Supermicro NVIDIA GB200 NVL72 System at Computex 2024 appeared first on ServeTheHome.

via ServeTheHome July 22, 2024

Forum

Community is one of the main topics I touch on here. My community, my social media is an email and iMessage, but I thought I could do more. I did such an experiment last year and I quit soon after. I don't think I was ready for it. Today I still don&#…

via Michal Zelazny July 21, 2024

Weekly Update 409

It feels weird to be writing anything right now that isn't somehow related to Friday's CrowdStrike incident, but given I recorded this video just a few hours before all hell broke loose, it'll have to wait until next week. This week, the issue…

via Troy Hunt July 21, 2024

Generated by openring