【StoneDB Class】入门第一课:数据库知识科普

船火儿
• 阅读 553

在没有出现数据库之前,数据存储在文本中,这种数据存储方式不管是管理还是查询,效率都是极其低下的,数据之间没有关联性。到了1970年,IBM研究员 E.F.Codd 发表了论文"A Relational Model of Data for Large Shared Data Banks",该论文中第一次提出了关系模型的概念,为关系型数据库奠定了基础,才有了后面涌现的如IBM的DB2、甲骨文的Oracle等优秀的关系型数据库。一直到上世纪90年代,数据库都是以关系型数据库为主。但随着数据量的增长,关系型数据库已无法满足更多的应用场景,数据库领域便随之出现了非关系型数据库。

数据库分类

数据库用于数据的存储和访问,不同类型的数据库也会满足不同的场景需求。如果你的数据库对事务没有要求,且读写是高并发的,那么你可以选择一款非关系型数据库。如果你的数据库主要存储历史数据,且访问频率少,那么你可以选择一款高压缩比,且读优化的数据库。如果你的数据库既有交易类业务,又有复杂分析类业务,那么你可以选择一款有混合存储引擎的数据库。
【StoneDB Class】入门第一课:数据库知识科普
数据库按照数据模型来划分,可分为关系型数据库和非关系型数据库。关系型数据库的数据是高度组织化和结构化的,可以使用结构化查询语言进行复杂的查询。非关系型数据库的数据是非结构化的,没有声明性查询语言,代表着不仅仅是SQL。关系型数据库注重事务的强一致性,而非关系型数据库注重可扩展性。数据库市场使用广泛的关系型数据库有 Oracle 、 MySQL 、 SQL Server ,数据库市场使用广泛的非关系型数据库有 Redis 、MongoDB 。
数据库按照数据分布来划分,可分为集中式数据库和分布式数据库。集中式数据库是一个或者多个数据库实例管理一份数据,每个数据库实例都可以看到全部数据,属于 Shared-Everything 架构。分布式数据库是每个数据库实例管理自己的数据,全量数据是所有数据库实例管理的数据的总和,属于 Shared-Nothing 架构。
【StoneDB Class】入门第一课:数据库知识科普
数据库按照数据处理来划分,可分为 OLTP 数据库、OLAP 数据库以及 HTAP 数据库,StoneDB 就是一款一体化实时 HTAP 数据库,后面几个课程会给大家深入介绍。OLTP 数据库适用于交易类系统,特征是大并发的小型事务处理,单次处理的数据量小。OLAP 数据库适用于分析类系统,特征是并发小,系统吞吐量高,单次处理的数据量大。HTAP 数据库是一种新型的架构,指的是混合事务和分析处理过程,出现 HTAP 的目的是打破 OLTP 和 OLAP 之间的壁垒。

数据库瓶颈

传统数据库经过五十多年的发展,不管是数据库本身的稳定性,还是数据库厂商的技术支持度,都已经非常的成熟。数据库厂商在官网提供的丰富学习资料,对使用者来说很容易学习这款数据库。但随着时代的发展,特别是出现互联网技术,数据库的数据量是指数增长的,那么传统数据库不仅在并发和存储上存在瓶颈,在可扩展性也是有限的。

当传统关系型数据库出现无法满足业务场景的需求,如出现高并发的海量数据存储时,出现了分布式数据库。分布式数据库由多台服务器组成,不仅提供更多的连接访问,还提供更多的存储容量,在可扩展性方面也是线性的。分布式数据库解决了传统数据库的瓶颈,然而分布式数据库也不是完美的无懈可击。

在事务一致性方面,传统数据库很容易保证 ACID ,而分布式数据库由多个数据库实例组成,分布在一个网络环境中,为了保证事务的一致性,引入了两阶段提交、三阶段提交、补偿事务。分布式事务在管理开销也是较大的,比如对悲观锁的支持,虽然一致性读无需持有锁,但查询也可能会被阻塞。

在基于成本的执行计划方面,由于数据分布在不同的节点,再加上分布式算法的复杂度,SQL 是否能保证有一个稳定的执行计划。

在数据一致性方面,分布式数据库以多副本进行存储时,数据的一致性问题变得更为复杂。假设正在更新某个副本时服务器发生故障,在这种情况下如何确保故障恢复后服务器上的副本与其他副本保持一致。

国产数据库

多年来国外数据库厂商处于绝对的主导地位,随着近几年IT国产化战略的提出,国内涌现出了多个数据库厂商,形成了百家争鸣。有发展多年的关系型数据库,如达梦、人大金仓、南大通用等;有势头猛进的分布式交易型数据库,如 TiDB 、 OceanBase 等;也有稳扎稳打的分布式分析型数据库 GaussDB 。
【StoneDB Class】入门第一课:数据库知识科普
(国产数据库)

StoneDB 作为自主设计、研发的国内首款基于 MySQL 内核打造的开源 HTAP 数据库,在同一个数据库实例中采用行列混合存储的方案,解决了 TP 和 AP 的问题,同时可实现与 MySQL 的无缝切换。由于100%兼容 MySQL ,让运维变的更简单,用户的体验感也更佳。
下节课我们将带大家深入了解 StoneDB 的系统架构和功能特点,请持续关注。关于StoneDB的任何问题,都可以加我V咨询:StoneDB_2022 。

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Wesley13 Wesley13
4年前
RAC环境单实例启动数据库收到ORA
     在RAC环境中,如果你在没有启动节点的集群服务的情况下单实例启动数据库,将收到类似如下的报错:\oracle@rhel1u01\$sqlSQL\Plus:Release10.2.0.5.0ProductiononTueApr215:00:272013Copyright(
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
4年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
4年前
MySQL数据库表设计规范
一、数据库设计1、一般都使用INNODB存储引擎,除非读写比率<1%,才考虑使用MYISAM存储引擎;其他存储引擎请在DBA的建议下使用。2、Storedprocedure(包括存储过程,函数,触发器)对于MYSQL来说还不是很成熟,没有完善的出错记录处理,不建议使用。3、UUID(),USER()这样的
Stella981 Stella981
4年前
Django之Django模板
1、问:html页面从数据库中读出DateTimeField字段时,显示的时间格式和数据库中存放的格式不一致,比如数据库字段内容为2012082616:00:00,但是页面显示的却是Aug.26,2012,4p.m.答:为了页面和数据库中显示一致,需要在页面格式化时间,需要添加<td{{dayrecord.p\_time|date:
Easter79 Easter79
4年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
4年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Wesley13 Wesley13
4年前
thinkphp 基本配置
12returnarray(34//定义数据库连接信息5'DB\_TYPE''mysql',//指定数据库是mysql67'DB\_HOST''localhost',89'DB\_NAME''uchome',//数据库名1011'DB\_USER''root
Wesley13 Wesley13
4年前
MySQL数据库的安装和配置
MySQL数据库的安装和配置1、数据库概念​数据库就是保存数据的地方,在没有数据库之前,我们是这样保存数据的:​1.随意的存到了一个文件中数据格式也是千差万别的​2.软件开发目录规范​规定了数据存放的位置ps:数据都是保存在本地的2、数据库如何保存数据的?