ES 服务器 索引、类型仓库基类 BaseESStorage
/*******************************************************
*
* 作者:朱皖苏
* 创建日期:20180508
* 说明:此文件只包含一个类,具体内容见类型注释。
* 运行环境:.NET 4.0
* 版本号:1.0.0
*
* 历史记录:
* 创建文件 朱皖苏 20180508 14:00
*
*******************************************************/ using DBEN.Basic.ElasticSearch;
using Elasticsearch.Net;
using Nest;
using System;
using System.Collections.Generic;
using System.Linq; namespace DBEN.ITEngine.Storages
{
/// <summary>
/// ES 服务器 索引、类型仓库基类
/// </summary>
/// <typeparam name="T"></typeparam>
public abstract class BaseESStorage<T> where T : class, IESEntity
{
protected ElasticClient client; protected string index = string.Empty;
protected string type = nameof(T).ToLower(); /// <summary>
/// 默认的初始化 client
/// </summary>
/// <param name="nodes">服务器集群</param>
/// <param name="index">索引名</param>
protected virtual void InitClient(IEnumerable<Uri> nodes, string index)
{
var pool = new StaticConnectionPool(nodes); var settings = new ConnectionSettings(pool);
settings.DefaultIndex(index);
settings.DisableDirectStreaming(true);
client = new ElasticClient(settings.ThrowExceptions());
var exits = client.IndexExists(index); if (!exits.Exists)
{
CreateIndex(index + "_real", index);
}
this.index = index;
} /// <summary>
/// 当索引不存在的时候创建索引。
/// 根据 <see cref="Nest.ElasticsearchTypeAttribute"/> 自动映射类型
/// 默认创建 NumberOfShards = 5
/// 默认创建 NumberOfReplicas = 1,
/// </summary>
/// <param name="index"></param>
protected virtual void CreateIndex(string index, string Alias)
{
var descriptor = new CreateIndexDescriptor(index)
.Settings(s =>
s.NumberOfShards().NumberOfReplicas())
.Aliases(m => m.Alias(Alias))
.Mappings(ms => ms.Map<T>(m => m
.Properties(ps => ps
.Text(t => t.Name(n => n.Id))
.Text(t => t.Name(n => n.CreateTime).Index(true)))
.AutoMap())); client.CreateIndex(descriptor); } /// <summary>
/// 新增单条信息
/// </summary>
/// <param name="entity">数据实体</param>
public bool InsertOne(T t)
{
if (!string.IsNullOrEmpty(t.Id))
{
return false;
}
var rsp = client.Index(t, o => o.Index(index).Id(t.Id));
t.Id = rsp.Id;
return rsp.ApiCall.Success;
} /// <summary>
/// 新增多条信息
/// </summary>
/// <param name="entity">数据实体</param>
public void InsertMany(IEnumerable<T> t)
{
var rsp = client.IndexMany(t, index);
} /// <summary>
/// 更新单条信息
/// </summary>
/// <param name="t"></param>
/// <param name="id"></param>
public void UpdateOne(T t, Id id)
{
var rsp = client.Index<T>(t, o => o.Index(index).Id(id));
} /// <summary>
/// (根据名称精确查找)
/// </summary>
/// <param name="t"></param>
/// <param name="field"></param>
/// <param name="value"></param>
/// <returns></returns>
public ISearchResponse<T> Find(string field, string value)
{
var searchResult = client.Search<T>(s => s
.Index(index)
.Query(q => q
.Term(e => e.Suffix(field), value)));
return searchResult;
} /// <summary>
/// 根据名称精确查找一个
/// </summary>
/// <param name="field"></param>
/// <param name="value"></param>
/// <param name="compare"></param>
/// <returns></returns>
public T FindFirst(string field, string value, Func<T, bool> compare = null)
{
var searchResult = client.Search<T>(s => s
.Index(index)
.Query(q => q
.Term(e => e.Suffix(field), value)));
return searchResult.Hits.Select(m => m.Source)
.FirstOrDefault(m => compare == null ? true : compare.Invoke(m));
} /// <summary>
/// 模糊查询
/// </summary>
/// <param name="field"></param>
/// <param name="value"></param>
/// <returns></returns>
public ISearchResponse<T> FuzzyFind(string field, string value)
{
//模糊搜索
var searchResult = client.Search<T>(s => s
.Index(index)
.From()
.Size()
.Query(q => q
.MatchPhrase(d => d.Field(field).Query(value).Slop())));
return searchResult;
} /// <summary>
/// term any item of <paramref name="values"/>
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="descriptor"></param>
/// <param name="field"></param>
/// <param name="values"></param>
/// <returns></returns>
protected QueryContainer TermAny(QueryContainerDescriptor<T> descriptor, Field field, IEnumerable<string> values)
{
QueryContainer q = new QueryContainer();
foreach (var value in values)
{
q |= descriptor.Term(t => t.Field(field).Value(value));
}
return q;
} public long Count()
{
return client.Count<T>(s => s.Index(index)).Count;
}
}
}
ENtity
using Nest;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace DBEN.Basic.ElasticSearch
{ public interface IESEntity
{
string Id { get; set; } DateTime CreateTime { get; set; }
}
}
ES 服务器 索引、类型仓库基类 BaseESStorage的更多相关文章
- .NET基础 (11)类型的基类System.Object
类型的基类System.Object1 是否存在不继承自System.Object类型的类2 在System.Object中定义的三个比较方法有何异同3 如何重写GetHashCode方法 类型的基类 ...
- C# System.Object基类
System.Object 基类 System.Object在.Net中是所有类型的基类,任何类型都直接或间接地继承自System.Object.没有指定基类的类型都默认继承于System.Objec ...
- C++中基类的析构函数为什么要用virtual虚析构函数
知识背景 要弄明白这个问题,首先要了解下C++中的动态绑定. 关于动态绑定的讲解,请参阅: C++中的动态类型与动态绑定.虚函数.多态实现 正题 直接的讲,C++中基类采用virtual虚析构函数是 ...
- 枚举基类Enum详解
本文主要是对枚举类型的基类Enum类做一个介绍: 首先,Enum类位于java.lang包下,根据类的介绍可以发现,Enum类是Java中所有枚举类的父类,将枚举作为一个set或者Map的keys来使 ...
- “每日一道面试题”.Net中所有类的基类是以及包含的方法
闲来无事,每日一贴.水平有限,大牛勿喷. .Net中所有内建类型的基类是System.Object毋庸置疑 Puclic Class A{}和 Public Class A:System.Object ...
- 基类的析构函数写成virtual虚析构函数
虚函数作用:动态绑定,实现多态效果. 场景问题: 派生类中有资源需要回收,而在编程中采用多态,由基类的指针指向派生类,则在释放的时候,如果基类的析构函数不是virtual,则派生类的析构函数得不到释放 ...
- C++中基类虚析构函数的作用及其原理分析
虚析构函数的理论前提是 执行完子类的析构函数,那么父类的虚构函数必然会被执行. 那么当用delete释放一个父类指针所实例化的子类对象时,如果没有定义虚析构函数,那么将只会调用父类的析构函数,而不会调 ...
- (C++)浅谈多态基类析构函数声明为虚函数
主要内容: 1.C++类继承中的构造函数和析构函数 2.C++多态性中的静态绑定和动态绑定 3.C++多态性中析构函数声明为虚函数 1.C++类继承中的构造函数和析构函数 在C++的类继承中, 建立对 ...
- System.Object 基类
System.Object在.Net中是所有类型的基类,任何类型都直接或间接地继承自System.Object.没有指定基类的类型都默认继承于System.Object. 基类特性 正由于所有的类型都 ...
随机推荐
- 困扰的问题终于解决了-docker时区不正确的问题修改记
前一阵子有一台服务器,mysql的时间比北京时间晚了8个小时.我知道是时区的问题,但是不知道为什么弄成这样,宿主机没有问题,后来一看mysql的docker,时区是错的. mybatis-plus打印 ...
- 2019-1-29-C#-Task.Run-和-Task.Factory.StartNew-区别
title author date CreateTime categories C# Task.Run 和 Task.Factory.StartNew 区别 lindexi 2019-01-29 16 ...
- webpack学习(三)配置loader
首先搞清楚两个问题: 1 什么是loader? 2 为啥要用各种loader 答: loader 就是各种打包规则,为什么要用是显而易见的,因为webpack还没智能到给它什么文件都能打包,对于js文 ...
- P1096 4个数的全排列
题目描述 输入4个有序的个位数.按照字典序输出它们的全排列. 输入格式 输入四个数字a,b,c,d.(0<=a,b,c,d<10) 输出格式 输出它们的全排列.每个排列占一行.而且每个排列 ...
- java 泛型的上限与下限
设置泛型对象的上限使用extends,表示参数类型只能是该类型或该类型的子类: 声明对象:类名<? extends 类> 对象名 定义类:类名<泛型标签 extends 类>{ ...
- Educational Codeforces Round 54 (Rated for Div. 2) D Edge Deletion (SPFA + bfs)
题目大意:给定你一个包含n个点m条边的无向图,现在最多在图中保留k条边,问怎么删除多的边,使得图中良好的节点数最多,求出保留在图中的边的数量和编号. 良好的节点定义为:删除某条边后该点到点1的最短距离 ...
- NuGet 符号服务器
在新的 VisualStudio 支持使用 NuGet 符号服务器,可以支持新的 Portable PDB 调试符号的库,本文告诉大家如何打包上传带符号的库和使用符号服务器 在 2018 的 11 月 ...
- Vue-route页面切换过渡动画
重点: 1.判断路由前进还是后退 2.切换时动画如何实现 1.需要给各个页面定义层级,切换路由时判断进入哪个层级页面,如果进入层级高页面做前进动画,否则做后退动画在路由定义中添加meta自定义参数 ...
- C# 已知点和向量,求距离的点
已知一个点 P 和向量 v ,求在这个点P按照向量 v 运行距离 d 的点 B . 已经知道了一个点 P 和他运动方向 v ,就可以通过这个求出距离点 P 为 d 的点 B. 首先把 v 规范化,规范 ...
- Fetch 记录
encodeURI()不会对本身属于URI的特殊字符进行编码,例如冒号.正斜杠.问号和井字号:而encodeURIComponent()则会对它发现的任何非标准字符进行编码. Fetch 请求body ...