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平台 ...
随机推荐
- JUC源码分析-线程池篇(一):ThreadPoolExecutor
JUC源码分析-线程池篇(一):ThreadPoolExecutor Java 中的线程池是运用场景最多的并发框架,几乎所有需要异步或并发执行任务的程序都可以使用线程池.在开发过程中,合理地使用线程池 ...
- C# WinfForm 控件之dev报表 XtraReport (四) 动态绑定主从关系表
一般的单据都是由主从关系的,比如部门与人员.单据表头与表身.仓库与存货.分类与档案等等 所以主从关系是报表用的最多的 1.准备数据库 简单方便 --主表 create table RdRecord ( ...
- Ansible角色
Ansible角色介绍 官方地址: https://docs.ansible.com/ansible/latest/user_guide/playbooks_reuse_roles.html 角色目录 ...
- linux 下格式化命令小记
mkfs.ext4 /dev/sda1 # 格式化为ext4分区mkfs.ext3 /dev/sda1 # 格式化为ext3分区mkfs.ext2 /dev/sda1 # 格式化为e ...
- Laravel Class 'Doctrine\DBAL\Driver\PDOMySql\Driver' not found
Laravel: 5.5.* 在迁移中有重命名操作的时候,运行 php artisan migrate 会提示 Class 'Doctrine\DBAL\Driver\PDOMySql\Driver' ...
- this.$router.push
跳转详情页this.$router.push({ path: `/activityDetails/${id}` })
- net core发邮件——MimeKit
var message = new MimeMessage(); message.From.Add(new MailboxAddress("谁发的", "发送方的邮件地址 ...
- Python 刷题知识点
if : elif : else : print('{0} \n{1} \n{2}' .format((a + b), (a - b), (a * b))) print(*[num**2 for nu ...
- grep命令 一 文本搜索工具
使用正则表达式搜索文本,并把匹配的行打印出来.使用权限是所有用户. 基本使用 grep [option] pattern filename: pattern如果是表达式或者超过两个单词的, 需要用引号 ...
- DOM——属性操作
属性操作 非表单元素的属性 href.title.id.src.className var link = document.getElementById('link'); console.log(l ...