ES(ElasticSearch)是一款分布式全文检索框架,底层基于基于Lucene实现。ES与传统数据的区别主要有:

1.结构名称不同

一个ES集群可以包含多个索引(数据库),每个索引又包含了很多类型(表),类型中包含了很多文档(行),每个文档使用 JSON 格式存储数据,包含了很多字段(列)。

关系型数据库

数据库

ElasticSearch

索引

类型

文档

字段

2.ES分布式搜索,传统数据库遍历式搜索

ES支持分片和复制,从而方便水平分割和扩展,复制保证了es的高可用与高吞吐。

在ES中,当你创建一个索引(数据库)的时候,你可以指定你想要的分片的数量。每个分片本身也是一个功能完善并且独立的索引(数据库),索引可以被放置到集群中的任何节点上。分片优点:

1.允许你水平分割/扩展你的内容容量

2.允许你在分片之上进行分布式的、并行的操作,进而提高性能/吞吐量

3.分片的分布,它的文档怎样聚合回搜索请求,完全由Elasticsearch管理

3.ES采用倒排索引,传统数据库采用B+树索引

假设一个文档(用id标识)是有许多的单词(用value标识)组成的,每个单词可能同一个文档中重复出现很多次,也可能出现在不同的文档中。

正排索引:从文档角度看其中的单词,表示每个文档都含有哪些单词,以及每个单词出现了多少次(词频)及其出现位置(相对于文档首部的偏移量)。

倒排索引:从单词角度看文档,标识每个单词分别在那些文档中出现(文档ID),以及在各自的文档中每个单词分别出现了多少次(词频)及其出现位置(相对于该文档首部的偏移量)。

简单理解,

正排索引:id ---> value

倒排索引:value ---> id

ES中为所有字段默认都建了倒排索引。

4.ES没有用户验证和权限控制

5.ES没有事务的概念,不支持回滚,误删不能恢复

6.ES免费,完全开源;传统数据库部分免费

7.结合工作举例

例如,要计算出2.38亿会员中有多少80后的已婚的上海男士。

传统数据库执行时间: 5个小时左右

ES执行时间:1分钟

ES与传统数据库的比较相关推荐

  1. ES与传统数据库,为什么用ES?

    一.简介 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口操作ES,也可以利用Java API.Elastics ...

  2. es和传统关系型数据库的类比

    es和传统关系型数据库的类比 Ralational DB -> Databases -> Tables -> Rows           -> Columns Elastic ...

  3. 浅谈搜索引擎和传统数据库(ES,solr)

    作为小白一枚,一直不理解既然已经有数据库存储的数据了,为什么还要有搜索引擎这些东西,而且这些搜索引擎和数据库之间是怎样的联系或者协同工作的.最近研究了很多,慢慢的好像理解了其中意思了,所以在此分享,也 ...

  4. ES 与关系型数据库的对比

    SQL 与 NOSQL • ES 与关系型数据库的对比 – 在 ES 中,文档归属于一种 类型 (type) ,而这些类型 存在于索引 (index) 中,类比传统关系型数据库 – DB -> ...

  5. 探究 | Elasticsearch 与传统数据库界限

    0.引言 现在几乎网上所有资料都说数据存储在传统数据库,再在 es 中同步一份数据作为检索使用,但是也都没有很详细的说明为什么要这么做,而且在 es 本身可以存储数据的情况下,存储两份数据是不是没有必 ...

  6. elasticsearch 与 传统数据库的区别与选用

    elasticsearch 与 传统数据库的区别与选用 1:ES ElasticSearch是一款分布式全文检索框架,底层基于Lucene实现. ElasticSearch 使用 JSON 格式存储数 ...

  7. Redis,传统数据库,HBase,Hive区别联系

    首先介绍各个数据库: Redis: 传统数据库: HBase: Hive: 转载于:https://www.cnblogs.com/gentle-awen/p/10179148.html

  8. 【DBMS 数据库管理系统】数据库 -> 数据仓库 ( 数据处理类型 | 传统数据库 | 数据库不适用于分析型应用 )

    文章目录 一.数据处理类型 二.传统数据库技术 三.传统数据库 不适用于 分析型 ( DSS 决策支持系统 ) 应用 原因 四.事务性处理 与 分析型处理 性能特性不同 五.数据集成问题 六.数据集成 ...

  9. 图解Nosql(hbase)与传统数据库的区别

    图解Nosql(hbase)与传统数据库的区别 http://www.aboutyun.com/thread-7804-1-1.html (出处: about云开发) 问题导读: 1.nosql数据库 ...

最新文章

  1. 最新自然语言处理领域顶会论文大合集!
  2. 报表中利用隐藏列对扩展格显示值求和
  3. 面试(之)三赴上海易传媒—揭秘之旅
  4. 2.1.3 正则化(归一化)的用处以及何时使用
  5. 怎么添加本地音乐_网易云音乐:60G免费云盘+隐藏彩蛋、技巧
  6. python中基例_Python python从入门到实践(5) --代码复用
  7. java中可以作为GC Roots的对象
  8. 一个基础的 HTML 文档有哪些标签?(3)
  9. 基于 Docker 打造前端持续集成开发环境
  10. word-break:break-all和word-wrap:break-word的区别
  11. Python-Pandas之两个Dataframe的差异比较
  12. 2019年11月数据库流行度排行:前三甲大幅下跌 PM 应云而升 国产续领风云
  13. jj斗地主服务器维护几点能好使啊,JJ斗地主比赛常见问题
  14. 关于手眼标定的误差计算
  15. 摄影测量与遥感数据精度表格
  16. 亚马逊多账号注册怎么操作?多账号注册有哪些解决方案?
  17. 关于推荐系统的全面调研与探讨!千万别错过!
  18. KeyMix for Mac破解教程
  19. S合金元素对不锈钢组织和性能的影响
  20. vr属于计算机什么领域,vr技术是什么

热门文章

  1. 将一副完整的位图均分成n块位图显示
  2. mysql数据库备份和还原的命令_Mysql数据库备份和还原常用的命令
  3. 随想录(linux下的pv操作)
  4. java 获取所有线程,Java 实例 - 获取所有线程
  5. 简述java的异常机制_JAVA异常机制简述
  6. onenetsim定位功能吗_餐饮空间的设计原则和特点,你了解吗?
  7. mysql8参数方案_Mysql8.0及以上 only_full_group_by以及其他关于sql_mode原因报错详细解决方案...
  8. idea如何给oracle添加数据_intelij idea下使用java和JDBC连接oracle数据库及简单的SQL操作...
  9. php java 读取所有txt_paip.文件读写api php java python总结.txt
  10. CVE-2021-34527: Windows Print Spooler 蠕虫级远程代码执行漏洞