salesforce之apex开发3---soql和sosl简单查询

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


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

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

例如:

list 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 acclst = [select Id, Name from Account];


第二种是字符串拼接:

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


两种方式比较:

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

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

例如:

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


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

soql中的关联查询:

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

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


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

例如:

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

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





你可能感兴趣的:(salesforce)