我是靠谱客的博主 端庄项链,最近开发中收集的这篇文章主要介绍salesforce之apex开发3---soql和sosl简单查询,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

下面是笔者自己做salesforce开发整理的知识点,如果有不详细的,可以参照https://developer.salesforce.com,查看salesforce开发文档。


我们用salesforce进行数据搜索方式跟oracle,mysql的查询方式很类似:

SELECT  'fields' 
FROM 'object' 
WHERE 'filter'

例如:

list<Account> acclst = [select Id, Name from Account];
Account acc = [select Id, Name from Account];


*注意以上两种写法的区别:

1.第一种用list接收,得到的是搜索到的Account的满足条件的集合

2.第二种用Account这个object直接接收,得到的是一条Account记录。

3.如果没有满足条件的Account,第二种方式会抛出queryException,其实我们可以理解为第二种是在第一种方式的基础上,又获取了第一条数据,但是由于整个获取的list为空,因此在用空对象获取第一条数据时,就会抛出异常。

4.如果没有满足条件的Account,在用list接收时,会得到一个空的list对象,而不是null。因此在获取完之后注意不要直接用下面的判断方式

//不严谨的判断
if(acclst != null){ 
    //execute 
} 


可以用以下两种方式判断:

if(acclst != null && acclst.size() > 0){
    //execute
}


//salesforce提供的判断方式
if(acclst.isEmpty()){
    //execute
}



当然soql的查询在apex中也有两种写法:

第一种便捷查询:

list<Account> acclst = [select Id, Name from Account];


第二种是字符串拼接:

String sql = 'select Id, Name from Account';
list<Account> acclst = Database.query(sql);


两种方式比较:

1.如果在搜索条件确定的情况下,个人建议用第一种方式会比较简便。

2.如果是动态控制搜索条件的情况下(尤其有多个控制条件的时候),建议用第二种方式会比较方便。

例如:

//便捷查询
String name;
if(name != null){
    list<Account> acclst = [select Id, Name from Account where Name = :name];
}else{
    list<Account> acclst = [select Id, Name from Account];
}


//字符串拼接
String name;
String sql = 'select Id, Name from Account';
if(name != null){
    sql += ' where Name =:name ';
}
list<Account> acclst = Database.query(sql);

soql中的关联查询:

如果该object有关联到其他object的关联字段(例如:lookup字段)。我们可以这样查询:

list<Event__c> eventlst = [select Id, Name, Account__r.Name from Event__c];
这里的Account__r.Name就是通过Account__c关联字段关联获取Account中Name字段的值。


salesforce还提供了sosl方式的便捷查询,从多个表中查询

例如:

List<List<SObject>> searchList = [FIND 'myName*' IN ALL FIELDS RETURNING Account (Id, Name),
Contact, Opportunity, Lead];
这种方式会返回多个满足条件的list。

注意:这里的模糊查询使用*标记,不是soql中的%。





最后

以上就是端庄项链为你收集整理的salesforce之apex开发3---soql和sosl简单查询的全部内容,希望文章能够帮你解决salesforce之apex开发3---soql和sosl简单查询所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(81)

评论列表共有 0 条评论

立即
投稿
返回
顶部