This is a Salesforce Data Cloud step-by-step guide that shows how to create a Vector Search Index from Knowledge Base Articles in a Core Salesforce Org and then Query that Vector Search Index from the external Query API. This post will be informative for any tech team looking to use the Salesforce Vector Database with external platforms such as ChatGPT Enterprise, Slack, or any preferred agentic middleware solution (n8n, Langchain, Flowise, Zapier, Make.com, etc). Here's the overall idea:
data:image/s3,"s3://crabby-images/77c2f/77c2f54e2aa39559f0a57a5da70a1dc4e4c14b14" alt=""
I aim to show each step needed from start to finish. There are a lot of steps involved, so if you're already familiar with how to set up Data Cloud, you may want to skip to the API section at the end.
Prerequisite: You will need access to a Salesforce Org and Salesforce Data Cloud in order to use the Salesforce Vector Database (Search Index). There are several free ways to do this. As an example, you could:
- Sign up for a Data Cloud Developer Edition
- Enable Data Cloud in your Enterprise Edition (EE) or above Production Org
- If you are an SI or ISV partner, you could create a Simple Demo Org (SDO)
I will use a Simple Demo Org (SDO) for this demonstration.
Step 1: Set up Data Cloud
First, you'll need to set up Data Cloud in your org. Assuming it has already been provisioned, you'll find the Data Cloud Setup link to the admin interface at the top right, under the standard Salesforce setup link.
data:image/s3,"s3://crabby-images/fd058/fd058bff1cf713f969390adf07c7caa4ad7c515c" alt=""
1.1: Set Up Your Data Cloud Instance
Once there, you can enable data cloud from the Data Cloud Setup Home.
data:image/s3,"s3://crabby-images/a665c/a665cd71cb0211ad738a0c896ff6fb525eabe0b7" alt=""
1.2: Salesforce CRM Integration
Next, you will need to connect your Core Org to Data Cloud. This is a little confusing if you're using Data Cloud from within your Core Org, but it works the same way as you connect other external Orgs (or other Data Sources). You need to set up the connection using Salesforce CRM Setup under the Integrations heading.
data:image/s3,"s3://crabby-images/4fd71/4fd719619eb0de10f9676ea458e64b5fe17cbdc0" alt=""
In this instance, you can see I've installed Sales Cloud (1.3) and am installing the Service Cloud (5.0) Data Bundle (bottom right). The CDP bundles listed haven't been installed. This brings up a standard Package Install page, and I'm choosing to install it for all users.
data:image/s3,"s3://crabby-images/88aa1/88aa127651c58b95e3b083b189333013a3ca8f5d" alt=""
1.3: Permission Set Setup
Lastly, since we will be setting up a Data Stream for Knowledge Articles, Data Cloud will need Read All and Modify All permissions on your Core Org Knowledge Article Objects. Data Cloud uses an integration user named Platform Integration User with a Permission Set named Data Cloud Salesforce Connector.
To provide access to Knowledge, you need to give access to the Data Cloud Salesforce Connector Permission Set for these Objects under the Permission Set Object Settings:
- CaseArticle__c
- KCSArticle_DataCategorySelection__c
- KCSArticle_ka__c
- KCSArticle_kav__c
- Knowledge
data:image/s3,"s3://crabby-images/ecba5/ecba5058d54e95603309142160c3248943769044" alt=""
You also need to provide access to Knowledge Management in the Permission Set App Settings.
data:image/s3,"s3://crabby-images/c1cf9/c1cf944ee3d98092cfe7f80ecdd97098a4061809" alt=""
Step 2: Data Streams Setup
A Data Stream is a pipeline that brings data into Data Cloud for unification, analysis, and activation. In this case, you'll be bringing that Data into the Data Cloud environment in the Core Org that you're already in. But it could also be a separate Org, or multiple other Core Orgs, or other services entirely like Amazon S3, Airtable, Snowflake, or CosmosDB.
For these next steps, you will want to exit Data Cloud Setup, and select just regular old Data Cloud from the App Launcher for further... ah... well, setup. The first tab next to Home is Data Streams, which is where you should go next.
data:image/s3,"s3://crabby-images/30247/30247b103bf1069b2597df80ec884636ac10bcd3" alt=""
Next, we're going to select the Salesforce CRM org that we connected back in Step 1.2
data:image/s3,"s3://crabby-images/d225d/d225d4ed5449e9d762f84251ed85018e404ca984" alt=""
After clicking Next, we'll be able to select the Knowledge Standard Data Bundle.
data:image/s3,"s3://crabby-images/29b05/29b05e931505faed0b95d568c28df83cc7de77b5" alt=""
You can see the Knowledge bundle includes 7 Objects
data:image/s3,"s3://crabby-images/6c39b/6c39b70cf398aa6937b74173d18952becbef0d9e" alt=""
This is where you may get this error if you didn't get all of the Permission Set settings right above:
Insufficient Permissions: You do not have permission to import records for 1 object. Please check with your Salesforce Admin to make the following object available for use.
Knowledge: 7 Fields unavailable: VersionNumber, IsVisibleInPkb, IsLatestVersion, IsVisibleInPrm, ArticleMasterLanguage, IsVisibleInCsp, IsVisibleInApp.
If you get this error, make sure you've updated both the App Settings and the Object Settings for the Data Cloud Salesforce Connector Permission Set. See above for more info.
data:image/s3,"s3://crabby-images/3d100/3d100dc6a9b107ea5df805b152867ff3a4c3853f" alt=""
When you go to create your Data Stream, it won't include the actual Knowledge Article text by default. Since our goal is to create a vector search on the Knowledge Article text, we'll need to add that to the Data Stream by checking the box next to FAQ_Question_c and FAQ_Answer_c:
data:image/s3,"s3://crabby-images/d2459/d24598df7120f04022a91731d996f0fcc66707e7" alt=""
We'll leave these settings as their defaults before Deploying. The data model for Salesforce Knowledge is a little complicated, but the main thing to know for the purposes of this exercise is that the actual Knowledge Article text is contained in the KnowledgeArticleVersion Object, which is shown as Knowledge__kav_Home here ("kav" is short for Knowledge Article Version).
data:image/s3,"s3://crabby-images/88339/88339a39efecc011ee3a128a4eff909a22103d65" alt=""
Once deployed, you'll see that you have some new Data Streams that have not yet been refreshed, meaning they don't have any data ingested yet.
data:image/s3,"s3://crabby-images/90aa8/90aa82764d8518260bdcd9d922b51fb865fe419a" alt=""
This process has also created corresponding Data Lake Objects and Data Model Objects for you:
data:image/s3,"s3://crabby-images/9e3a0/9e3a0efe1deedc40e533e8c723b1354a456b288b" alt=""
data:image/s3,"s3://crabby-images/e535a/e535a1e90ab898d9b7e5e777ff55f5cdc519c062" alt=""
Data Streams need to be refreshed before you can do anything with them, so we'll go ahead and refresh each one:
data:image/s3,"s3://crabby-images/a5f12/a5f124f38e54292cc959561c752c7175c18212d0" alt=""
Lastly, the default Knowledge Data Bundle doesn't map the KB article content FAQ_Question__c or FAQ_Answer__c to the Data Model Object (DMO), so that's the last step we need to do. In the Knowledge__kav_Home Data Stream, click the Review button in the Data Mapping section.
data:image/s3,"s3://crabby-images/4dab0/4dab036c8287eeec89569d95b9efcbdc732a1dac" alt=""
The field label for FAQ_Question__c is Question" and the field label for FAQ_Answer__c is "Details":
data:image/s3,"s3://crabby-images/3766b/3766bb57ff91a74bdcf3ba10e98f346ddc3deac3" alt=""
These fields aren't mapped by default, so we'll map Details to Article Content, and Question to a Custom Field (click Add New Field) that we'll name Article Question. Click the Save and Close button at the top of the page, and then the Refresh Now button from the Knowledge__kav_Home Data Stream page.
data:image/s3,"s3://crabby-images/8363f/8363f702336077de328927ce343c9ba6358ea43d" alt=""
Step 3: Search Index Setup
The Search Index tab is where you will set up a Vector Search index for your Unstructured Data Lake Object (DLO). In the Data Cloud App, click the More tab to see a tab named Search Index. Click New, and you'll be presented with a dialog box like this. We will choose Advanced Setup.
data:image/s3,"s3://crabby-images/f34bd/f34bdc7c4a7640fdfe5bb25ee1b1aac46de93782" alt=""
There are two types of Search Index available today. Vector Search and Hybrid Search.
Step 3.0: What is a Vector Database?
Either will work for the purposes of our demonstration, but here's a brief description of the difference:
A Vector Database takes long strings of text (a.k.a. "unstructured data"), breaks it up into smaller chunks (usually half a page to a page worth of text), and converts it into "Vectors" (a.k.a. an ordered list of numbers). Here's what a Vector looks like in Pinecone.io, a popular Vector Database.
data:image/s3,"s3://crabby-images/37db4/37db43828a1645ba89c50da7dfa176547af7e9ca" alt=""
A Vector Database makes it possible to do what's called "Similarity Search" or "Semantic Search", which is much more powerful for Generative AI Q&A than a typical Keyword search.
Here's an example: let's imagine you are searching through a database of clipart metadata looking for a picture of a pony.
- A Keyword Search will match images where the word "pony" is used exactly, but it won't find pictures of small horses, or other 4-legged barnyard animals.
- A Vector Search will correctly identify that a "pony" is similar to a "horse", which is also more similar to a "cow" than it is to an "apple". This sort of semantic understanding is what makes a Vector Database so powerful.
data:image/s3,"s3://crabby-images/8a549/8a5494f4031b86aaa7883e6c83dd34577b01ea3e" alt=""
Vector Search is extremely powerful for this sort of semantic matching, but it's not great at other types of basic queries that computers are normally pretty good at like "how many apples are there?" or "what time is it". That's why the best option for any application is often a hybrid between Vector Search and a Keyword Search of additional metadata or data.
Step 3.1: Select the Search Type
Back to Salesforce Data Cloud, the Vector Search type does exactly what is illustrated above. We'll select Hybrid Search because it includes a Vector Search, but it also adds on some elements of Keyword Search in order to round out those shortcomings of a Vector Search.
data:image/s3,"s3://crabby-images/bd4af/bd4af10b6ff44aec87f4418566e76fa312197cc7" alt=""
Step 3.2: Chunking
Vector Databases ingest data through a process called "Chunking and Embedding". If you think of vectorizing a long document, like a book, the first step will be to chunk it into smaller sections. There are a variety of different chunking strategies that try to keep contextually similar things within the chunk, but for the most part the idea is to create more manageable pieces of information before generating the vector embeddings.
data:image/s3,"s3://crabby-images/4793d/4793d40ab86b4edf2c0f374411233fc23ba7ffe0" alt=""
In this step, we'll select the fields that contain the most text for the Knowledge Article in order to use those for our Vector Embeddings
data:image/s3,"s3://crabby-images/89761/89761355ef2cc467a79abf5bf2bff3b628d218a6" alt=""
data:image/s3,"s3://crabby-images/5919e/5919ee81e82a8adadd801cc6e3246072d6e678e2" alt=""
Step 3.3: Embedding
The next step is to pass these Chunks to an Embedding Model. This uses a Large Language Model (LLM) to generate vector "embeddings" to store in the Vector Database. Each of the LLM vendors have options for vector embeddings (OpenAI, Anthropic, etc).
data:image/s3,"s3://crabby-images/75f18/75f1869c28e19f4f9200cee8a8aa4e2e64c548f1" alt=""
Step 3.4: Filtering and Ranking
In this step you can control the search results a bit by adding filters and ranking the results.
data:image/s3,"s3://crabby-images/3a56d/3a56d99d48b9edca4efd669b83f902457850995c" alt=""
data:image/s3,"s3://crabby-images/ab69f/ab69f62eb1e9fca76fab3337f514f0c97d63b280" alt=""
Step 3.5: Review and Build
That's it. Just click Save at this point and let it run.
data:image/s3,"s3://crabby-images/ab065/ab065e686183cbe1f401d79ce670c8b128b5bb58" alt=""
Step 4: Query API
Now that you've built a Vector Search Index from Data Cloud, we've finally gotten to the goal of this article! In this step, we will show how to query Vector Index from an external source using the Query API. We'll be using Postman in order to do this, so start off by signing up for a free account at https://www.postman.com/
Step 4.1: Postman Setup
To show how to use the Query API, we'll start with the Postman Data Cloud API interface published by salesforce-developers. Just follow the instructions on Postman to fork it into your own environment with the "Fork the collection using this button".
data:image/s3,"s3://crabby-images/dc80c/dc80c0e8ec99fb3e20b666b924ab9d925018639a" alt=""
Step 4.2: Postman Authentication with Data Cloud
Postman makes this step very easy. From the Overview tab of the Salesforce Data Cloud APIs page, click on the Authentication tab, scroll down and click the "Get new Access Token" button, and then "Use Token" from the dialog box that comes up next.
data:image/s3,"s3://crabby-images/72e69/72e69c10265b23308bc4eca020488094ad63988b" alt=""
You can then Complete the authentication by clicking Send in the script under the Auth folder:
data:image/s3,"s3://crabby-images/eda00/eda005df63d9654e9cbdffbcfdd5a6fdfe9958b1" alt=""
Step 4.3: Postman Authentication with Data Cloud
Next we will complete a Vector Search with the Query API V2. Here's an example SQL query for: "What is our return policy".
SELECT c.Chunk__c, v.score__c, v.ArticleNumber__c from vector_search(TABLE(Knowledge_Article_Version_index__dlm), 'What is our return policy', '', 100) as v join Knowledge_Article_Version_chunk__dlm as c on v.SourceRecordId__c=c.RecordId__c ORDER by v.score__c desc LIMIT 10
With this, you can see the vector search results from the API
data:image/s3,"s3://crabby-images/cc98f/cc98fa6af79bc4ad6e18ca9220514218c9d12a5f" alt=""
Summary and Next Steps
This article was a step-by-step guide that shows how to set up Data Cloud from scratch, ingest Knowledge Articles into an Unstructured Data Model Object (DMO) using a Data Stream, and then create a Vector Search Index from that unstructured data. From that point, we've shown how to query this from an external source using PostMan in order to authenticate and query the Data Cloud Query API V2.
The next step from this point will be to show how to build a middleware that can connect a User Experience like ChatGPT Enterprise with this Vector Search API. Stay tuned for more.