如何选择一款数据库?

news2025/1/21 1:05:16

1主流数据库技术介绍

常见的数据库模型主要分为SQL关系型数据库NoSQL非关系型数据库。其中关系型数据库分为传统关系数据库和大数据数据库,非关系型数据库分为键值存储数据库、列存储数据库、面向文档数据库、图形数据库、时序数据库、搜索引擎存储数据库及其他,如下图。

(1)关系型数据库

关系型数据库是一种基于关系模型的数据库管理系统。根据DB-Engine发布的2021年8月全球数据库排行中关系型数据库前10名如下图所示。

关系型数据库的特点主要是有一个数据库由多张表构成、每张表都有用户定义的表结构信息(schema)来描述表格的结构,数据表是面向行增长的,而列的模式是相对固定的。

(2)非关系型数据库

1)键值(Key-Value)存储数据库

数据按照键值对的形式进行组织、索引和存储。KV存储非常适合不涉及过多数据关系业务关系的业务数据,同时能有效减少读写磁盘的次数,比SQL数据库存储拥有更好的读写性能。其典型的产品 有Redis、Memcache。

2)列存储(Column-oriented)数据库

列存储数据库又被称为面向可扩展性的分布式数据库,它反转了传统的行存储数据库。这种数据库通常用来应对分布式存储海量数据。典型产品:Cassandra(AP)、HBase(CP)

3)面向文档(Document-Oriented)数据库

文档数据库旨在将半结构化数据存储为文档,其中文档包括 XML、YAML、JSON、BSON、office 文档等。其灵感是来自于Lotus Notes办公软件,典型产品:MongoDB、CouchDB。

4)图形数据库

图形数据库是应用图形理论存储实体之间的关系信息。实体会被作为顶点,而实体之间的关系则会被作为边。典型产品:Neo4J、InforGrid

5)时序数据库

时序数据是基于时间的一系列的数据。在有时间的坐标中将这些数据点连成线,往过去看可以做成多纬度报表,揭示其趋势性、规律性、异常性;往未来看可以做大数据分析,机器学习,实现预测和预警。时序数据库就是存放时序数据的数据库,并且需要支持时序数据的快速写入、持久化、多纬度的聚合查询等基本功能。对比传统数据库仅仅记录了数据的当前值,时序数据库则记录了所有的历史数据。同时时序数据的查询也总是会带上时间作为过滤条件。典型产品:InfluxDB、Prometheus(普罗米修斯)、OpenTSDB(底层基于HBase)

6)搜索引擎存储

搜索引擎数据库是一类专门用于数据内容搜索的非关系数据库。搜索引擎数据库使用索引对数据中的相似特征进行归类,并提高搜索能力。目前市场比较火的搜索引擎Solr和Elasticsearch等,这两者均是开源搜索引擎。

2主流数据库选型分析

(1)关系型数据库选型分析

1)主流关系型数据库分析

下表选取常见关系型数据库进行对比:

Oracle

Microsoft SQL Server

MySQL

开放性

能在所有主流平台上运行;

完全支持所有工业标准;

采用完全开放策略,使客户选择适合的解决方案,对开发商全力支持

只能在Windows环境上运行

跨多平台

可伸缩性、并行性

提供高用性和高伸缩性簇方案

SQL Server并行实施和共存模型并不成熟;难处理日益增多用户数和数据卷;伸缩性有限。

提供主从、分区、分库分表的伸缩性方案。

安全性

最高,获得最高认证级别的ISO标准认证

没有任何安全证书

没有获得安全认证

性能

最高

次之

最低,但在大量查询读取数据的条件下,MySQL一定程度上可媲美Oracle

数据库事务处理能力

最高

较高

默认状态不支持事务处理,但MySQL中的InnoDB存储引擎支持事务

图形化管理操作便捷性

较高

最高

较低,主要以命令的形式

部署方式

支持单节点、复制、集群等部署方式

提供HA故障转移功能

支持集群

主要应用场景

例如银行,金融等对可用性,健壮性,安全性,实时性要求极高的业务;零售,物流等对海量数据存储分析要求很高的业务。

介于Oracle和MySQL间

大都集中于互联网Web应用

全球应用排名(2021年8月)

第一

第三

第二

对支持硬件基础要求

最高

较高

最低

成本

最高

较高

最低,对个人来版是免费的

管理维护

操作较复杂,需要技术

最简单

较易

院内使用情况

较少

最多

较多

如果需要基于行的关系数据库且需要事务处理和复杂的数据库功能,那么Oracle和SQL Server用得较多。对于小型桌面和移动应用,一般可选择SQLite数据库。

(2)非关系型数据库选型分析

具体选型根据实际业务情况,并结合平台技术架构再进行选择,比如分布式文件系统选择。

3结论

综合考虑平台对数据实时性、安全性、数据量剧增性及数据库系统可扩展性、数据库对频繁读写的支持能力,以及常用的结构化数据、部署使用成本等,建议以Oracle数据库为主要关系型数据库,其他辅助用数据库的选择根据实际业务情况软件平台技术架构进行筛选。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/397659.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java集合类

在了解Java集合类之前,我们必须首先了解java.util包,这个包提供了所有集合相关的接口和类。 集合是用来存储数据类型的一种数据结构,提到存储数据类型的数据结构我们最先想到的应该是数组,接下来我们简单回顾下Java中集合和数组的…

Xilinx ZYNQ 7000 HDMI

High-Definition Multimedia Interface (HDMI) 参考xilinx application note XAPP460 HDMI来自High-Definition Multimedia Interface 高分辨率多媒体接口,多媒体一般包含图像和声音。 Transition Minimized Differential Signaling (TMDS) 是HDMI的物理层。 TMDS…

春招冲刺(十一):前端面试之网络总结

网络总结 Q1: GET和POST的请求的区别 应用场景:Get是一个幂等请求,一般用于请求资源。post不是幂等请求,一般用于修改资源。缓存:Get请求一般缓存,Post一般不缓存报文格式:Get请求体一般为空,…

【Linux】linux | 修改dns | 修改网卡dns

一、说明1、业务需要,需要修改服务的dns的地址2、改成阿里的二、操作查询需要修改dns的网卡ifconfig说明1: 留意ens192,即网卡名称查看网卡配置文件信息cd /etc/sysconfig/network-scripts ll备份cp /etc/sysconfig/network-scripts/ifcfg-en…

Advantest爱德万直流电源维修电压电流发生器ADCMT系列

Advantest爱德万电源维修常见型号:ADCMT6240A/B;R6243/R6246;ADCMT系列。 维修品牌: 安捷伦Agilent/HP、泰克Tektronix、安立Anritsu、罗德施瓦茨、爱德万Advantest、艾法斯/马可尼IFR/Marconi、吉时利Keithley、日立Hitachi、 松…

【BOOST C++】组件编程(2)-- 组件的设计原理

GitHub - ros2/demos at foxy 一、说明 为了研究ROS2的组件编程,首先要理解如何何为组件。组件本是微软的发明物体,但是在ubuntu上需要自己从底层实现,就说ROS2不用你写,但是就能看明白也是需要一点理论功底的。本篇按照COM内幕的…

【2223sW3】LOG1

写在前面 好好学习,走出宿舍,走向毕设! 一些心路历程记录,很少有代码出现 因为鬼知道哪条代码到时候变成毕设的一部分了咧,还是不要给自己的查重挖坑罢了 23.3.6 lammps代码修改 因为学姐要中期答辩了,…

用Biome-BGC模型如何模拟水循环过程

在Biome-BGC模型中,对于碳的生物量积累,采用光合酶促反应机理模型计算出每天的初级生产力(GPP),将生长呼吸和维持呼吸减去后的产物分配给叶、枝条、干和根。生物体的碳每天都按一定比例以凋落方式进入凋落物碳库;对于水份输运过程…

2023/3/8集合之TreeSet HashSet简介 不含代码

TreeSet : 底层是由TreeMap维护的 无序的,不可重的 底层结构 : 红黑树(平衡二叉树) 特点 : 查询效率高,默认升序排序引用场景 : 适合应用在存储多个单个值的数据的集合,去重的,自动升序排序的场景新增方法:新增了一些与比较大小相关的方法 遍历方式 1)foreach 2)iterator 1测试…

【C语言学习笔记】:图解指针变量

1 指针变量的基本操作基本操作 int a,*iptr,*jptr,*kptr;iptr &a;jptr iptr;*jptr 100;kptr NULL; 图解: 1.1 己址和己空间 指针变量也是一个变量,对应一块内存空间,对应一个内存地址,指针名就是己址。这空内存空间多大…

42-Golang中的单元测试

Golang中的单元测试需求传统方法基本介绍单元测试快速入门总结综合案例需求 在工作中,我们会遇到这样的情况,就是去确认一个函数,或者一个模块的结果是否正确 传统方法 在main函数中,调用addUpper函数,看看实际输出…

322. 零钱兑换 279.完全平方数

322. 零钱兑换 完全背包问题&#xff0c;需要注意的是数组的初始值。 class Solution {public int coinChange(int[] coins, int amount) {int[] dp new int[amount1];for(int i 0;i < amount;i){dp[i] Integer.MAX_VALUE;}dp[0] 0;for(int i 0;i < coins.length;i…

使用 create-react-app 脚手架搭建React项目

❀官网 1、安装脚手架&#xff1a;npm install -g create-react-app 2、查看版本&#xff1a;create-react-app -V &#xff01;&#xff01;&#xff01;注意 Node版本必须是14以上&#xff0c;不然会报以下错误。 3、创建react项目&#xff08;项目名不能包含大写字母&…

Windows上一款特别好用的画图软件

安装 废话不多说&#xff0c;打开windows的应用商店&#xff0c;搜索draw.io&#xff0c;点击获取即可。 画图 draw.io的布局左边是各种图形组件&#xff0c;中间是画布&#xff0c;右边是属性设置&#xff0c;文件扩展名是.drawio。 点击左边列表中的图形可以将它添加到画…

设计模式(十七)----行为型模式之模板方法模式

行为型模式用于描述程序在运行时复杂的流程控制&#xff0c;即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务&#xff0c;它涉及算法与对象间职责的分配。 行为型模式分为类行为模式和对象行为模式&#xff0c;前者采用继承机制来在类间分派行为&…

二、JVM内存结构

文章目录运行时数据区子系统程序计数器&#xff08;PC寄存器&#xff09;虚拟机栈本地方法接口和本地方法栈堆运行时数据区子系统 1、Java虚拟机定义了若干程序运行期间使用到的运行时数据区&#xff0c;其中有一些会随着虚拟机启动而创建&#xff0c;随着虚拟机推出而销毁。另…

SpringBoot接口 - 如何对参数进行校验

在以SpringBoot开发Restful接口时, 对于接口的查询参数后台也是要进行校验的&#xff0c;同时还需要给出校验的返回信息放到上文我们统一封装的结构中。那么如何优雅的进行参数的统一校验呢&#xff1f;什么是不优雅的参数校验后端对前端传过来的参数也是需要进行校验的&#x…

刷题笔记7 | 454.四数相加II 、383. 赎金信 、 15. 三数之和 、 18. 四数之和 、 总结

454.四数相加II 给你四个整数数组 nums1、nums2、nums3 和 nums4 &#xff0c;数组长度都是 n &#xff0c;请你计算有多少个元组 (i, j, k, l) 能满足&#xff1a; 0 < i, j, k, l < n nums1[i] nums2[j] nums3[k] nums4[l] 0 输入&#xff1a;nums1 [1,2], nums…

全网最全Fiddler抓包教程,超过十万人学习此教程!

零基础玩转Fiddler抓包在测试领域应用实战&#xff01;各位做测试的同学想必对抓包工具fiddler并不陌生&#xff0c;但是很多同学可能没有总结过它的用法&#xff0c;下面我总结了fiddler一些常用的用法。 Web端抓包配置 打开Fiddler&#xff0c;Tools -> Fiddler Options…

界面组件DevExpress WinForms v22.2 - 升级对HTML CSS的支持

DevExpress WinForms拥有180组件和UI库&#xff0c;能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序&#xff0c;无论是Office风格的界面&#xff0c;还是分析处理大批量的业务数据&#xff0c;它都能轻松胜…