We’re Heading to CNX ’25. Let's Meet in Chicago! Join HIC at Salesforce Connections'25 for conversations, collaboration, and co-creation.

There are many methods in Salesforce to create records, like creating them manually, using a data loader to upload many records at once, or using an apex class. But what if there was a way where a person could just email with data of records to his Salesforce org and records will be created automatically?

Well, this is possible with Salesforce Email Services!

In Salesforce, Email Service can be configured easily and then with some code, you can do basically anything in your org.

So, in this blog today, we will share how to create bulk records in Salesforce with an email.

For this, we will be creating Lead records with Email service and if any Lead is not created the user will be notified which Lead is not created and the cause of the error.

So let’s start the demo!

Step 1:

First, navigate to Setup > Email Services and you will be greeted with this screen:

image1

The above prompt is suggesting you create an apex class that is using this line of code

Code

And you should exactly do what it says and make an apex class with this code to start with.

Step 2:

After making that class you can now click on “New Email Service” and create a new email service(Obviously!).

image2

Step 3:

Give a name to your Email Service, select the apex you created, and fill in other fields as per your requirement.

For this demo, we are receiving a CSV to create records so we will be selecting “All” in Accept Attachments and Convert Text Attachments to Binary Attachments.

Now we have created our email service but still want an email address to which we can send emails to create records. For that, just click on the email service that you just created and select “New Email Address” and an email will be created for you.

image3

And that’s all you have to set up your Email Service.

Step 4:

All that is left to do is write the code for it. For that open the Apex class you created and make the following changes:

Apex Code:

In the above code, I am also using a CSV Reader class “SimpleCsvReader” that you can copy from here:

SimpleCsvReader:

Code

Step 5:

For testing the Email service we will be using this CSV file with Lead Records to insert them:

image4

In this, we left a required field empty to get the error message in return.

When we send this CSV as an attachment in an email to the email address we got from the email service it creates those records in the Lead object.

image5

All the Leads got created except for the one without the company field and for that, we received a CSV in our email showing us the error:

image6

User Testing:

If you want to test this implementation you can send your Lead record CSV in the fields in the above respective order to this email:

leademailgeneration@h-22bywfmax7f6x6qu97pjee6j3mt19x3rizfvq4ane0sdy1bi5p.2w-qutegeaj.ap16.apex.salesforce.com

Conclusion

In conclusion, Salesforce Email Services provide a simple and efficient way to create records in Salesforce by just sending an email with the required data. By setting up an email service and creating an apex class to handle incoming emails, we can easily create records in bulk with the data provided in the email.

Additionally, we can plan to notify the user if any records were not created and provide the cause of the error. This method can save a lot of time and effort, especially when dealing with large amounts of data.

Like the blog? Share your valuable feedback with us and stay connected for more such interesting Salesforce development services!

Related Articles
Expert Guide On Nominal XIRR Calculation Using LWC in Salesforce

When building financial tools within Salesforce, handling irregular cash flows with precision is a must. Whether you’re developing investment trackers, portfolio performance dashboards, or funding monitors, calculating Nominal XIRR (Extended Internal Rate of Return) becomes essential. In this blog, you’ll learn how to build a Lightning Web Component (LWC) in Salesforce that calculates Nominal XIRR […]

Read More
Beginners Guide to Making Your LWC Component Multilingual

If you’re wondering how to make your LWC component multilingual, you’re already ahead of the curve. Global users expect content in their native language, and Salesforce gives you the tools to deliver exactly that. With Custom Labels and the Translation Workbench, you can easily localize your Lightning Web Components without touching a single line of […]

Read More
Hands-On Guide Building a Drag-and-Drop Form Builder Using Lightning Web Components

Drag-and-drop interfaces are a user experience staple, and when paired with the power of Lightning Web Components (LWC), they unlock dynamic, highly interactive Salesforce components. In this blog post, we’ll walk you through how to build a custom drag-and-drop form builder in LWC. Users can drag form fields like text inputs and dropdowns into a […]

Read More
Please Make Blog Banner How to Create an Agentforce Enabled Scratch Org in Salesforce 100 1

Setting up an Agentforce-enabled scratch org is the most important step for developers who want to experiment with AI features such as Prompt Builder and Einstein GPT. Whether you’re developing the next generation CRM software or experimenting with how generative AI may improve user experience, a scratch org equipped with Agentforce is your playground. Follow […]

Read More
Step-by-Step Guide to Enhance Your LWC Development Workflow with the Logger API

Are you looking to streamline your LWC development workflow but confused about how to do it? Then you are in the right place. The Salesforce Logger API is a powerful tool that helps you monitor, debug, and improve code quality in real time.  This step-by-step guide walks you through how to set it up and […]

Read More
Enhancing Your Salesforce Experience with a Custom Activity Component

In today’s fast-paced business landscape, productivity hinges on streamlined workflows and intuitive interfaces. While Salesforce offers robust activity tracking capabilities, sometimes the standard components fall short of specific organizational needs.  That’s where a Custom Activity Component comes in—designed to tailor your activity management experience, boost user efficiency, and provide deeper insights into customer interactions. In […]

Read More
Our Location worldwide
Indian Flag India
3rd Floor, A-10, Pegasus Tower, Sector 68, Noida, Uttar Pradesh 201301 +91-1203117884
United States of America Flag USA
333 West Brown Deer Road Unit G – 366 Milwaukee WI, USA 53217 +1(262) 310-7818
United Kingdom Flag UK
7 Bell Yard, London, WC2A 2JR +44 20 3239 9428
Canada Canada
HIC Global Solutions INC
43 Lafferty Lane, Richmond Hill, L4C 3N8, CA +1(262) 310-7818