软件设计 2017-03-30
salesforce里有soql、sosl两种查询语法,soql针对模糊搜索也有‘like’关键字,然而只能针对其自带字段如:Name、Id;对于自定义添加的字段如:Message__c、Note__c采用‘like’模糊检索则会报错。
然而,一般情况业务需求上更多的会对自定义字段有模糊检索的需求,因此对此作了一些调查,然而国内salesforce并不流行,论坛博客相关讨论也很少,参考了部分JP博客、官方的相关文档,总结出两种思路来应对自定义字段模糊检索问题。
FIND ‘sear*’ IN ALL FIELDS RETURNING Table__c
思路:通过find的search语句执行得到一个模糊检索的结果集,然后将结果集中的id取出放入集合内,再在主soql文中加入‘id in (模糊搜索记录的id集合)’的where条件从而达到模糊查询的目的。
if (note != null && note != '') {
          String findQuery = 'FIND \'' + note + '*\' IN ALL FIELDS RETURNING Test__c';
          List<List<sobject>> results = search.query(findQuery);
          Set<Id> ids = new Set<Id>();
          for(List<sobject> result: results){
            for(sobject obj : result){
              ids.add(obj.Id);
            }
          }
          string strIds = '';
          Integer i = 0;
          for (String str : ids) {
            if(i != ids.size()-1)
            {
              strIds += '\''+str+'\'';
              strIds +=  ',';
              }else{
                strIds += '\''+str+'\'';
              }
              i++;
            }
            if(strIds != null && strIds != '')
            {
              soql += ' And id IN ('+strIds+')';
            }else{
              soql += ' And id = '+'\'\'';
            }
          }  通过文档说明和测试发现:
因此,综合考虑,还是第二种方案更为可靠。
obj.col.contain(keyword)
思路:将soql执行得到的List集合遍历,对各个obj的Note__c字段进行关键字模糊搜索过滤(contain()函数),满足条件的添加到结果List中,最后返回结果List。
List<Test__c> temp = database.query(soql);
        List<Test__c> resultList = new List<Test__c>();
        if(strMemo!=null&&strMemo!=''){
          for(Test__c dr:temp){
            if(dr.Note__c!=null&&dr.Note__c!=''){
              if(dr.Msg__c.contains(strMemo)){
                resultList.add(dr);
              }
            }
          }
        }else{
          resultList = temp;
        }
        return resultList;  最后说下自己的看法,这种两种方法初看起来都有点效率低下,毕竟比起sql文中like来确实费劲不少,但就实际的页面效果来看并没有多大时间损耗,数据量万条以内可行性还是挺高的。