Elasticsearch.net一些开发笔记
.net下开发es半年多了,留下些笔记
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/combining-filters.html
//bool 和 dis_max 过滤器能并联多个过滤器一起
// should 各个子查询的关系式or
// 如果should有兄弟过滤器那么 should和他的兄弟过滤器就是 and关系
//must 各个子查询的关系是and ,must 子元素里里面的 所有兄弟过滤器是一个and的关系,必须都要满足才能被检索出来
//must的多个子查询是 and的意思 如果 只有一个子查询 为什么还加个 must???
//当没有 must 语句的时候,至少有一个 should 语句必须匹配。 当有must的时候 should就成了加分项
//查询语句用constant_score的意思是 constant_score 里面的查询都使用结构化查询 也就是不使用评分
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/_best_fields.html#dis-max-query
//dis_max 和 bool的区别是 dis_max 返回最佳字段 比如 搜索 Brown fox 被搜索内容里里面出现 Brown fox的的时候得分要高于单独 出现Brown和fox的内容
//dis_max 的子查询 queries 是什么意思???
//exists 和 missing 相当于 is not null 和 is null
//match 查询主要的应用场景就是进行全文搜索
//fields 数组能指定多个查询字段
//filter 过滤器能在查询指定用户的内容起到作用
//同样的数据如果被索引在不通的索引当中那么即便查询的时候是有条件一样 结果不一定是相同的,因为内容下各自的索引分片当中的权重不一样
//所以很多人一直有疑惑 为什么我搜索的内容和我想要的结果不也一样 比如以下数据
// index1 {content:中国驻洛杉矶领事馆遭亚裔男子枪击 嫌犯已自首}
// index2 { content:"你好中国"} { content:"我来自中国"}
//当你搜索 中国驻洛杉矶 的时候你预计是 index的数据排在前面 但是实际上是 index2的数据会排在前面 elasticsearch 中专业解释叫“被破坏的相关度”
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/multi-match-query.html
//multi_match相对match来说 multi_match查询为能在多个字段上反复执行相同查询提供了一种便捷方式 就是说使用multi_match包含的子查询能一条语句查询多个字段
//不需要些多个match 或者多个 term之类 直接使用fields 包含所有字段就ok
//match_phrase 相对match来说 match_phrase 查询时按照关键字的顺序来的 比如搜索 上海 李静 那结果中 上海 一定要在 李静的 前面 才能被搜索到
///cross_fields
///当查询 上海 李静 的时候 operator设置成 and type 设置成cross_fields 如果多个字段共同满足 有上海和李静 就符合查询(比如地址中有上海,名字中有李静)
// operator的值是 and和or minimum_should_match可以取代and和or 用百分百来匹配
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/_Improving_Performance.html
//rescore 结合 window_size 能对结果中的指定条数的数据进行 rescore_query(邻近查询) 查询 并且重新得分 提高结果精度
//minimum_should_match
/// 没有做分词的字段 也能使用 prefix 做局部查询 比如身份证是精确查询的 但是能使用 prefix 搜索430124开头的,但是不打分
/// wildcard 还能做正则匹配
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/scoring-theory.html
///创建索引的时候 如果为字段指定了 "index_options": "docs" 则表示 该字段搜索的时候忽略词频
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/query-time-boosting.html
//当在多个索引中搜索内容的时候可以通过 indices_boost 为各个索引整体提升权重
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/query-scoring.html 里面包含用 match 、multi_match 、term 、bool 和 dis_max 的导航
//https://www.elastic.co/guide/cn/elasticsearch/guide/current/_best_fields.html#dis-max-query
//dis_max 最佳查询
//如果一个稳定有 name adder 两个字段 当搜 key的时候 name adder互相竞争 是一样使用dis_max 查询 他将返回name后者adder两者匹配key的分数高的那个作为整体分数
//elasticsearch 查询批量删除
https://www.elastic.co/guide/en/elasticsearch/reference/5.2/docs-delete-by-query.html
https://blog.csdn.net/Sympeny/article/details/77876173
Elasticsearch.net一些开发笔记的更多相关文章
- [开发笔记]-未找到与约束ContractName Microsoft.VisualStudio.Text.ITextDocumentFactoryService...匹配的导出【转载自:酷小孩】
原文地址:http://www.cnblogs.com/babycool/p/3199158.html 今天打算用VisualStudio2012做一个js效果页面测试的时候,打开VS2012新建项目 ...
- EasyUI 开发笔记(二)
接上篇 :EasyUI 开发笔记(一) (http://www.cnblogs.com/yiayi/p/3485258.html) 这期就简单介绍下, easyui 的 list 展示, 在easy ...
- EasyUI 开发笔记(一)
由于某些原因,在公司做的后台需要改成类似于Ext.js 形式的后台,主要看好其中的 框架布局,以及tab开页面和弹出式内部窗体. 后来看看,改成EasyUI,较Ext.js 库小很多,也便于公司的初级 ...
- [Openwrt 项目开发笔记]:Openwrt平台搭建(一)
[Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 最近开始着手进行Openwrt平台的物联网网关设 ...
- Android移动APP开发笔记——Cordova(PhoneGap)通过CordovaPlugin插件调用 Activity 实例
引言 Cordova(PhoneGap)采用的是HTML5+JavaScript混合模式来开发移动手机APP,因此当页面需要获取手机内部某些信息时(例如:联系人信息,坐标定位,短信等),程序就需要调用 ...
- Android移动APP开发笔记——最新版Cordova 5.3.1(PhoneGap)搭建开发环境
引言 简单介绍一下Cordova的来历,Cordova的前身叫PhoneGap,自被Adobe收购后交由Apache管理,并将其核心功能开源改名为Cordova.它能让你使用HTML5轻松调用本地AP ...
- 开发笔记:基于EntityFramework.Extended用EF实现指定字段的更新
今天在将一个项目中使用存储过程的遗留代码迁移至新的架构时,遇到了一个问题——如何用EF实现数据库中指定字段的更新(根据UserId更新Users表中的FaceUrl与AvatarUrl字段)? 原先调 ...
- Lucene/Solr搜索引擎开发笔记 - 第1章 Solr安装与部署(Jetty篇)
一.为何开博客写<Lucene/Solr搜索引擎开发笔记> 本人毕业于2011年,2011-2014的三年时间里,在深圳前50强企业工作,从事工业控制领域的机器视觉方向,主要使用语言为C/ ...
- [openwrt 项目开发笔记]: 传送门
“Openwrt 项目开发笔记”系列传送门: [Openwrt 项目开发笔记]:Openwrt平台搭建(一) (2014-07-11 00:11) [Openwrt 项目开发笔记]:Openwrt平台 ...
随机推荐
- <爬虫>相关的知识
1.概念.工具和HTTP 什么是爬虫 模拟客户端发送网络请求,获取响应,按照规则提取数据 爬虫的数据去哪了 展示到网页上(百度新闻,今日头条) 进行分析,从数据中寻找规律(指数网站:百度指数) 需要的 ...
- swagger使用详解
1:认识Swagger Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法 ...
- RTL_PROCESS_MODULE_INFORMATION
typedef struct _RTL_PROCESS_MODULE_INFORMATION { HANDLE Section; // Not filled in PVOID MappedBase; ...
- bootstrap-自带插件(完成的小功能)
模态框 务必将模态框的HTML代码放在文档的最高层级内(也就是说,尽量作为 body 标签的直接子元素),以避免其他组件影响模态框的展现和/或功能. <!-- 触发模态框的按钮 --> & ...
- Tomcat爆破
把输入的账户和密码包起来 选择第三个模式 第一个添加用户名 第二个添加: 第三个添加密码 选择编码格式 取消打钩
- C# 简单的百度推送代码
前段时间搞推送来着,安卓方面用到了百度的推送服务,由于只是简单的用到安卓推送的通知功能,所以没用百度推荐的C# SDK,通过借鉴网上的各种资料和百度的API,费了老大劲终于折腾出来一段能用的代码(早知 ...
- vue 外卖app(3) 利用slot分发内容
1. 增加一个HeaderTop.vue <template> <header class="header"> <slot name="le ...
- 22. 异常(Eception)
1. 现实生活的病 现实生活中万物在发展和变化会出现各种各样不正常的现象. 1)例如:人的成长过程中会生病. |——病 |——不可治愈(癌症晚期) |——可治愈 |——小病自行解决(上火,牙痛) |— ...
- BASS HOME
http://www.un4seen.com/
- IOI 2005 River (洛谷 3354)
题目描述 几乎整个Byteland王国都被森林和河流所覆盖.小点的河汇聚到一起,形成了稍大点的河.就这样,所有的河水都汇聚并流进了一条大河,最后这条大河流进了大海.这条大河的入海口处有一个村庄--名叫 ...