前提条件--开发环境已安装 (自行百度)
客户端用的是nest
学习elasticSearch主要是要掌握像sqlserver要会操作数据结构的增删改和数据的增删改查,这里主要写elasticSearch的文档结构操作和文档数据操作
一、新建一个索引
/// <summary> /// 创建索引 /// </summary> /// <param name="indexName">索引名称</param> /// <param name="alias">索引别名</param> /// <param name="shards">索引分片数</param> /// <param name="replicas">索引备份数</param> /// <returns>返回是否创建成功</returns> public bool Create(string indexName, string alias, int shards = 5, int replicas = 0) { if (string.IsNullOrWhiteSpace(indexName)) { return false; } indexName = indexName.ToLower(); //如果索引名称已经存在,则不插入 if (IsExists(indexName)) { OriginalException = new Exception("索引已存在"); return false; } CreateIndexDescriptor createIndex = new CreateIndexDescriptor(ConnectionSettings); createIndex.Index(indexName); if (!string.IsNullOrWhiteSpace(alias)) { createIndex.AddAlias(alias); } createIndex.NumberOfReplicas(replicas).NumberOfShards(shards); var response = Client.CreateIndex(createIndex); if (response.ConnectionStatus.Success) { return true; } else { OriginalException = response.ConnectionStatus.OriginalException; return false; } }
当然先要new一个客户端实例client ,不然没法操作
private ElasticClient _client = null; /// <summary> /// es客户端实例 /// </summary> public ElasticClient Client { get { if (_client == null) { List<Uri> uris = new List<Uri>(); foreach (var item in Nodes) { uris.Add(new Uri(item)); } var connectionPool = new SniffingConnectionPool(uris); ConnectionSettings _connectionSettings = new ConnectionSettings(connectionPool, ""); if (!string.IsNullOrWhiteSpace(UserName)) { _connectionSettings = _connectionSettings.SetBasicAuthentication(UserName, Password); } _client = new ElasticClient(_connectionSettings ); } return _client; } }
可能也需要检查一下这个索引是不是已经存在
/// <summary> /// 判断索引是否存在 /// </summary> /// <param name="indexName">索引名称</param> /// <returns></returns> public bool IsExists(string indexName) { if (string.IsNullOrWhiteSpace(indexName)) { OriginalException = new ArgumentNullException("indexName", "indexName不允许为空"); return false; } return Client.IndexExists(i => i .Index(indexName)).Exists; }
如果不需要了是不是要删除这个索引呢
/// <summary> /// 删除索引 /// </summary> /// <param name="indexName">索引名或别名</param> /// <returns>执行结果,正确返回true,否则返回false</returns> public bool Delete(string indexName) { if (!IsExists(indexName)) { OriginalException = new Exception("索引不存在!"); return false; } var response = Client.DeleteIndex(m => m.Index(indexName)); return Helper.ConvertIResponse(response); }
如果基础不够的话可以看看这个http://es.xiaoleilu.com/
今天就写到这个,文笔不是太好,就按那个思路写了一些,方便初学者
觉得好的话,鼓励一下,点击一下推荐哦