【StoneDB Class】入门第一课:数据库知识科普
来源:SegmentFault
时间:2023-02-24 20:11:32 124浏览 收藏
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《【StoneDB Class】入门第一课:数据库知识科普》,涉及到MySQL、数据库,有需要的可以收藏一下
在没有出现数据库之前,数据存储在文本中,这种数据存储方式不管是管理还是查询,效率都是极其低下的,数据之间没有关联性。到了1970年,IBM研究员 E.F.Codd 发表了论文"A Relational Model of Data for Large Shared Data Banks",该论文中第一次提出了关系模型的概念,为关系型数据库奠定了基础,才有了后面涌现的如IBM的DB2、甲骨文的Oracle等优秀的关系型数据库。一直到上世纪90年代,数据库都是以关系型数据库为主。但随着数据量的增长,关系型数据库已无法满足更多的应用场景,数据库领域便随之出现了非关系型数据库。
数据库分类
数据库用于数据的存储和访问,不同类型的数据库也会满足不同的场景需求。如果你的数据库对事务没有要求,且读写是高并发的,那么你可以选择一款非关系型数据库。如果你的数据库主要存储历史数据,且访问频率少,那么你可以选择一款高压缩比,且读优化的数据库。如果你的数据库既有交易类业务,又有复杂分析类业务,那么你可以选择一款有混合存储引擎的数据库。
数据库按照数据模型来划分,可分为关系型数据库和非关系型数据库。关系型数据库的数据是高度组织化和结构化的,可以使用结构化查询语言进行复杂的查询。非关系型数据库的数据是非结构化的,没有声明性查询语言,代表着不仅仅是SQL。关系型数据库注重事务的强一致性,而非关系型数据库注重可扩展性。数据库市场使用广泛的关系型数据库有 Oracle 、 MySQL 、 SQL Server ,数据库市场使用广泛的非关系型数据库有 Redis 、MongoDB 。
数据库按照数据分布来划分,可分为集中式数据库和分布式数据库。集中式数据库是一个或者多个数据库实例管理一份数据,每个数据库实例都可以看到全部数据,属于 Shared-Everything 架构。分布式数据库是每个数据库实例管理自己的数据,全量数据是所有数据库实例管理的数据的总和,属于 Shared-Nothing 架构。
数据库按照数据处理来划分,可分为 OLTP 数据库、OLAP 数据库以及 HTAP 数据库,StoneDB 就是一款一体化实时 HTAP 数据库,后面几个课程会给大家深入介绍。OLTP 数据库适用于交易类系统,特征是大并发的小型事务处理,单次处理的数据量小。OLAP 数据库适用于分析类系统,特征是并发小,系统吞吐量高,单次处理的数据量大。HTAP 数据库是一种新型的架构,指的是混合事务和分析处理过程,出现 HTAP 的目的是打破 OLTP 和 OLAP 之间的壁垒。
数据库瓶颈
传统数据库经过五十多年的发展,不管是数据库本身的稳定性,还是数据库厂商的技术支持度,都已经非常的成熟。数据库厂商在官网提供的丰富学习资料,对使用者来说很容易学习这款数据库。但随着时代的发展,特别是出现互联网技术,数据库的数据量是指数增长的,那么传统数据库不仅在并发和存储上存在瓶颈,在可扩展性也是有限的。
当传统关系型数据库出现无法满足业务场景的需求,如出现高并发的海量数据存储时,出现了分布式数据库。分布式数据库由多台服务器组成,不仅提供更多的连接访问,还提供更多的存储容量,在可扩展性方面也是线性的。分布式数据库解决了传统数据库的瓶颈,然而分布式数据库也不是完美的无懈可击。
在事务一致性方面,传统数据库很容易保证 ACID ,而分布式数据库由多个数据库实例组成,分布在一个网络环境中,为了保证事务的一致性,引入了两阶段提交、三阶段提交、补偿事务。分布式事务在管理开销也是较大的,比如对悲观锁的支持,虽然一致性读无需持有锁,但查询也可能会被阻塞。
在基于成本的执行计划方面,由于数据分布在不同的节点,再加上分布式算法的复杂度,SQL 是否能保证有一个稳定的执行计划。
在数据一致性方面,分布式数据库以多副本进行存储时,数据的一致性问题变得更为复杂。假设正在更新某个副本时服务器发生故障,在这种情况下如何确保故障恢复后服务器上的副本与其他副本保持一致。
国产数据库
多年来国外数据库厂商处于绝对的主导地位,随着近几年IT国产化战略的提出,国内涌现出了多个数据库厂商,形成了百家争鸣。有发展多年的关系型数据库,如达梦、人大金仓、南大通用等;有势头猛进的分布式交易型数据库,如 TiDB 、 OceanBase 等;也有稳扎稳打的分布式分析型数据库 GaussDB 。
(国产数据库)
StoneDB 作为自主设计、研发的国内首款基于 MySQL 内核打造的开源 HTAP 数据库,在同一个数据库实例中采用行列混合存储的方案,解决了 TP 和 AP 的问题,同时可实现与 MySQL 的无缝切换。由于100%兼容 MySQL ,让运维变的更简单,用户的体验感也更佳。
下节课我们将带大家深入了解 StoneDB 的系统架构和功能特点,请持续关注。关于StoneDB的任何问题,都可以加我V咨询:StoneDB_2022 。
今天关于《【StoneDB Class】入门第一课:数据库知识科普》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
259 收藏
-
411 收藏
-
476 收藏
-
312 收藏
-
244 收藏
-
195 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习