elasticsearch 查询 query

对于 类型是 text的字段,并且分析器指明是ik_max_word的会建立倒排索引

查询的分类:

match查询:  会自动转换大小写,会分词,

term查询: 不会转换和分词,只能值匹配

terms查询: 可以给字段值传入数组, 这里有没有分词呢??????????应该和term一样的只会值匹配吧,要不为啥叫terms,待验证

控制查询的数量,  from,和size属性指明,可以用来分页

match_all: 搜索索引下的所有type

match_phrase: 满足分词后的所有词, slop参数, 分词后的最小距离

multi_match: 指明多个字段进行查询,比如两个字段中都进行查询是否有一个值, 并且这里面可以给不同的字段赋予不同的权重 通过^number

查询后返回的字段: stored_fields,它的值是个数组,这里值只会是store为true的字段 ,这样返回的是在 _fields里面,而不是其他的都是在_source里面

查询结果排序:  sort字段和query同级: 值是个数组,数组的元素是个字典,指明排序字段的升序降序,

查询范围: range字段,在query里面, 指明那个字段的范围  gte , great than equal , lte,    boost (权重), 对于时间类,可以使用"now"

模糊查询: wildcard   查询字符段里面有通配符

最重要的match和range

bool查询

包括: must should must_not filter

filter: 过滤数据并且不参与打分

must : 必须全部满足

should: 满足一个就行

must_not: 一个都不能满足

bool是在query下的,然后在四个下面按照query的格式写查询就好了

filter里面最好用term查询,同样多个值查询用terms

对于text进行分词会进行转换,大写变成小写,这个时候如果用terms查询的值是大写,那样也是不匹配的,所以term查询是不是最好用不进行分词的字段

查看分析器的结果: GET _analyze

ik_max_word 分的比较细, ik_smart 比较智能一点,可以这么说

数组和字典

组合查询: 在bool里面的must_not , should,must进行组合

嵌套查询: 直接bool下面的里面再嵌套bool就可以了

过滤空和非空:  bool filter 下面的 exists,, 不存在 must_not 然后exists  

原文地址:https://www.cnblogs.com/zdj8023/p/10899096.html

时间: 2024-10-11 06:37:59

elasticsearch 查询 query的相关文章

Func<T,T>应用之Elasticsearch查询语句构造器的开发

前言 之前项目中做Elasticsearch相关开发的时候,虽然借助了第三方的组件PlainElastic.Net,但是由于当时不熟悉用法,而选择了自己拼接查询语句.例如: string queryGroup = "{\"query\": {\"match\": { \"roomid\": \"FRIEND_12686_10035\" }}}"; //关键字查询 string queryKeyWord =

Elasticsearch查询类型

Elasticsearch支持两种类型的查询:基本查询和复合查询. 基本查询,如词条查询用于查询实际数据. 复合查询,如布尔查询,可以合并多个查询, 然而,这不是全部.除了这两种类型的查询,你还可以用过滤查询,根据一定的条件缩小查询结果.不像其他查询,筛选查询不会影响得分,而且通常非常高效. 更加复杂的情况,查询可以包含其他查询.此外,一些查询可以包含过滤器,而其他查询可同时包含查询和过滤器.这并不是全部,但暂时先解释这些工作. 1.简单查询 这种查询方式很简单,但比较局限. 查询last_na

(转)Elasticsearch查询规则------match和term

es种有两种查询模式,一种是像传递URL参数一样去传递查询语句,被称为简单搜索或查询字符串(query string)搜索,比如 GET /megacorp/employee/_search //查询全部员工 GET /megacorp/employee/_search?q=last_name:Smith //查询last_name为Smith的员工 另外一种是通过DSL语句来进行查询,被称为DSL查询(Query DSL),DSL是Elasticsearch提供的一种丰富且灵活的查询语言,该语

Elasticsearch教程(九) elasticsearch 查询数据 | 分页查询

Elasticsearch  的查询很灵活,并且有Filter,有分组功能,还有ScriptFilter等等,所以很强大.下面上代码: 一个简单的查询,返回一个List<对象> .. /**     * 根据Id 查询 SOBangg     * @param key     * @return     */    public static List findSOBanggById(String id) {        Client client = ESTools.client;    

Elasticsearch入门教程(五):Elasticsearch查询(一)

原文:Elasticsearch入门教程(五):Elasticsearch查询(一) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/vbirdbest/article/details/79228852 // 准备数据 PUT /shop/goods/1 { "name": "2017新款女装冬季外套ulzzang棉袄中长款棉衣韩版百搭棉服面包服", &quo

Elasticsearch入门教程(六):Elasticsearch查询(二)

原文:Elasticsearch入门教程(六):Elasticsearch查询(二) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/vbirdbest/article/details/79237950 地理坐标点geo-point 地理坐标点:是指地球表面可以用经纬度描述的一个点. 地理坐标点可以用来计算两个坐标间的距离,还可以判断一个坐标是否在一个区域中,或在聚合中. 地理坐标点不能被

Lucene 查询(Query)子类

QueryParser(单域查询) QueryParser子类对单个域查询时创建查询query,构造方法中需要传入Lucene版本号,检索域名和分词器. QueryParser parser = new QueryParser(Version.LUCENE_43, field, analyzer);// 查询字符串 Query query = parser.parse("key"); MultiFieldQueryParser(多域查询) MultiFieldQueryParser p

elasticsearch查询模板

最近在公司又用到了elasticsearch,也用到了查询模板,顺便写篇文章记录一下查询模板的使用. 以1个需求为例讲解es模板的使用: 页面上某个按钮在一段时间内的点击次数统计,并且可以以小时,天,月为单位进行汇总,并且需要去重. 创建索引,只定义3个字段,user_id, user_name和create_time: -POST /$ES/event_index { "mappings": { "event": { "_ttl": { &qu

ElasticSearch查询 第四篇:匹配查询(Match)

匹配(Match)查询属于全文(Fulltext)查询,不同于词条查询,ElasticSearch引擎在处理全文搜索时,首先分析(analyze)查询字符串,然后根据分词构建查询,最终返回查询结果.匹配查询共有三种类型,分别是布尔(boolean).短语(phrase)和短语前缀(phrase_prefix),默认的匹配查询是布尔类型,这意味着,ElasticSearch引擎首先分析查询字符串,根据分析器对其进行分词,例如,对于以下match查询: "query":{ "ma