目录
一、前言
自定义ES的DSL查询(dynamic ES Query Language)【DEQL】是针对非结构化信息加工、提取需求而设计的查询语言。DEQL可以任意组合搭配各类逻辑操作符,提供便捷、强大、复杂的查询功能。
存在问题思考:
现实项目中,不同用户都要求根据的自身查询条件来获取想要的数据。但是,对搜索中间件(如ES)了解程度、对表结构的“黑盒”、对业务复杂性等等,这些问题导致搜索效果往往不尽如意,很难做到满足所有用户的要求。
基于这些的思考,想设计一种查询规则,该规则简单化、易理解、智能化,有这些优点,更好地方便查询。存在的几点思考:
(1)、如何设计规则,能够简单易理解?
(2)、按照规则指定的SQL,如何完美解析?
(3)、EQL能支持的未来前景?
解决思路:
(1)、如何设计规则,能够简单易理解?
借助ES的DSL语句特点,来设计规则,后续将具体介绍。
(2)、如何代码实现DEQL翻译成ES的DSL?
后续代码实现。
(3)、EQL能支持的未来前景?
借助ES的分词特点,在结合ES拥有的丰富查询规则,后续会支持以下功能:
支持用户自定义且符合ES的EQL语句的功能查询;
针对fieldName特定字段查询能同时支持:简体搜繁体/繁体搜简体/中文搜索拼音等;
自适应匹配“用户的关键词”的正则规则、搜词