当前位置: 首页 > 文档资料 > Apex 中文教程 >

SOSL

优质
小牛编辑
145浏览
2023-12-01

每个企业或应用程序都将搜索功能作为基本要求之一。 为此,Salesforce.com提供了两种使用SOSL和SOQL的主要方法。 让我们在本章中详细讨论SOSL方法。

SOSL

在整个对象和整个字段中搜索文本字符串将使用SOSL完成。 这是Salesforce对象搜索语言。 它具有跨多个对象搜索特定字符串的功能。

SOSL语句计算为sObject列表,其中,每个列表包含特定sObject类型的搜索结果。 始终以与SOSL查询中指定的顺序相同的顺序返回结果列表。

SOSL查询示例

考虑一个商业案例,其中我们需要开发一个可以搜索指定字符串的程序。 假设,我们需要在Invoice对象的Customer Name字段中搜索字符串'ABC'。 代码如下 -

首先,您必须在Invoice对象中创建一条记录,其客户名称为“ABC”,以便我们可以在搜索时获得有效结果。

// Program To Search the given string in all Object
// List to hold the returned results of sObject generic type
List<list<SObject>> invoiceSearchList = new List<List<SObject>>();
// SOSL query which will search for 'ABC' string in Customer Name field of Invoice Object
invoiceSearchList = [FIND 'ABC*' IN ALL FIELDS RETURNING APEX_Invoice_c
   (Id,APEX_Customer_r.Name)];
// Returned result will be printed
System.debug('Search Result '+invoiceSearchList);
// Now suppose, you would like to search string 'ABC' in two objects,
// that is Invoice and Account. Then for this query goes like this:
// Program To Search the given string in Invoice and Account object,
// you could specify more objects if you want, create an Account with Name as ABC.
// List to hold the returned results of sObject generic type
List<List<SObject>> invoiceAndSearchList = new List<List<SObject>>();
// SOSL query which will search for 'ABC' string in Invoice and in Account object's fields
invoiceAndSearchList = [FIND 'ABC*' IN ALL FIELDS RETURNING APEX_Invoice__c
   (Id,APEX_Customer__r.Name), Account];
// Returned result will be printed
System.debug('Search Result '+invoiceAndSearchList);
// This list will hold the returned results for Invoice Object
APEX_Invoice__c [] searchedInvoice = ((List<APEX_Invoice_c>)invoiceAndSearchList[0]);
// This list will hold the returned results for Account Object
Account [] searchedAccount = ((List<Account>)invoiceAndSearchList[1]);
System.debug('Value of searchedInvoice'+searchedInvoice+'Value of searchedAccount'
   + searchedAccount);

SOQL

这与SOQL几乎相同。 您可以使用它一次只从一个对象获取对象记录。 您可以编写嵌套查询,也可以从您现在查询的父对象或子对象中获取记录。

我们将在下一章中探讨SOQL。