概述
下面是笔者自己做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字段)。我们可以这样查询:
这里的Account__r.Name就是通过Account__c关联字段关联获取Account中Name字段的值。list<Event__c> eventlst = [select Id, Name, Account__r.Name from Event__c];
salesforce还提供了sosl方式的便捷查询,从多个表中查询
例如:
这种方式会返回多个满足条件的list。List<List<SObject>> searchList = [FIND 'myName*' IN ALL FIELDS RETURNING Account (Id, Name), Contact, Opportunity, Lead];
注意:这里的模糊查询使用*标记,不是soql中的%。
最后
以上就是端庄项链为你收集整理的salesforce之apex开发3---soql和sosl简单查询的全部内容,希望文章能够帮你解决salesforce之apex开发3---soql和sosl简单查询所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复