• 概述  

  最近在弄阿里云的sls日志服务,该服务提供了一个搜索接口,可根据各种运算、逻辑等表达式搜出想要的内容。具体语法可见https://help.aliyun.com/document_detail/29060.html?spm=5176.doc29029.2.2.8PG8RA

  在开发中,我们需要用到该接口的查询需求会不断扩增,可能一开始只用and,后面加了or和not,再后来又多了key/value pair、数值比较等等。如果把这些处理逻辑放在业务逻辑中,未免太过暴力,而且非常不方便维护和阅读。尤其是当出现了复杂的复合逻辑时,比如:"a and b or (c and (d not e))",我们要先自己推算出具体的公式并显示的写在业务逻辑,显然这是很不合理的。所以,我要把这类处理逻辑单独抽离出来,查询条件当成一个个搜索的过滤条件Filter,再通过拼接类Assembler自动拼接成我们想要的逻辑表达式。

  • 设计单个过滤器

  需要首先想清楚的是,整体的表达式是由一个个单独的查询语句(运算表达式)组成的,而连接他们的是逻辑运算(与或非)。所以我的思路是,先将所有单独的运算表达式创建出来,最后通过逻辑运算将他们拼接在一起。

  下