【Mysql数据库从0到1】-入门基础篇--数据库了解

news/2024/12/29 14:53:00/

【Mysql数据库从0到1】-入门基础篇--数据库了解

    • 🔻一、数据库产生背景
    • 🔻二、数据库有关概述
    • 🔻三、数据库访问接口
    • 🔻四、数据库种类
    • 🔻五、数据库有关术语
    • 🔻六、常见DBMS排名
    • 🔻七、常见数据库介绍
      • 7.1 RDS(关系型数据库)
      • 7.2 NoSQL(Not Only SQL)——非关系型数据库
      • 7.3 面向文档数据库
      • 7.4 列式存储
      • 7.5 图数据库
      • 7.6 搜索引擎数据库
    • 🔻八、总结—温故知新

🔻一、数据库产生背景

随着互联网高速发展,大量的数据正在不断产生,如何对之存储、检索、管理成为了信息时代一个非常重要的问题。于是对数据的有效存储、高效访问、方便共享和安全控制等问题应运而生。

❓ 什么是数据库

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。如冰箱,如储物柜,乃藏数之地。

❓ 为什么要使用数据库

🔶 数据库可以结构化存储大量的数据信息,方便用户进行有效的检索和访问。

🔶 数据库可以有效地保持数据信息的一致性、完整性、降低数据冗余。

🔶 数据库可以满足应用的共享和安全方面的要求。

🔶 数据库技术能够方便智能化地分析,产生新的有用信息——数据挖掘、联机分析等技术。

在这里插入图片描述

🔻二、数据库有关概述

❓ 什么是数据库管理系统

数据库管理系统(DBMS)是数据库系统的核心软件之一,是位于用户与操作系统之间的数据管理软件,用于建立,使用和维护数据库。

它的主要功能包括数据定义、数据操作、数据库的运行管理、数据库的建立和维护等几个方面。

❓ 什么是数据库系统

数据库系统由以下 3 个部分组成:

数据库(DB)——用于存储数据的地方。
数据库管理系统(DBMS)——用于管理数据库的软件。
数据库应用程序——为了提高数据库系统的处理能力所使用的管理数据库库的软件补充。

❓ 什么是SQL(结构化查询)语言

SQL(Structured Query Language)是用于访问和操作数据库中的数据的标准数据库编程语言。

在这里插入图片描述

🔻三、数据库访问接口

不同的程序设计语言会有各自不同的数据库访问接口,程序语言通过这些接口,执行 SQL 语句,进行数据库管理。

🍀 ODBC (Open Database Connectivity,开放数据库互连)

ODBC为访问不同的 SQL 数据库提供了一个共同的接口。ODBC 使用 SQL 作为访问数据的标准。这一接口提供了最大限度的互操作性。一个应用程序可以通过共同的一组代码访问不同的 SQL 数据库管理系统。

一个基于 ODBC 的应用程序对数据库的操作不依赖任何 DBMS,不直接与 DBMS 打交道,所有的数据库操作由对应的 DBMS 的 ODBC 驱动程序完成。也就是说,不论是 MySQL 还是 Oracle 数据库,均可用 ODBC API 进行访问。由此可见,ODBC 的最大优点是能以统一的方式处理所有的数据库

🍀 JDBC(JDBC,Java 数据库连接)

JDBC用于 Java 应用程序连接数据库的标准方法,是一种用于执行 SQL 语句的== Java API==,可以为多种关系数据库提供统一访问,它由一组用 Java 语言编写的类和接口组成。

🍀 ADO.NET

ADO.NET 是微软在 .NET 框架下开发设计的一组用于和数据源进行交互的面向对象类库。ADO.NET 提供了对关系数据、XML 和应用程序的访问,允许和不同类型的数据源以及数据库进行交互。

🍀 PDO

PDO(PHP Data Object)为 PHP 访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数据。PDO 是 PHP 5 新加入的一个重大功能。

🔻四、数据库种类

🌿 层次数据库(Hierarchical Database,HDB)

层次数据库是最早研制成功的数据库系统,它把数据通过层次结构(树形结构)的方式表现出来。层次数据库曾经是数据库的主流,但随着关系数据库的出现和普及,现在已经很少使用了。

🎏代表:IBM 公司研制的 IMS(Information Management System)数据库。

🌿 关系型数据库(Relational Database,RDB)

关系型数据库是现在应用最广泛的数据库。关系型数据库在 1969 年诞生,可谓历史悠久。和 Excel 工作表一样,关系型数据库也采用由行和列组成的二维表来管理数据,所以简单易懂。同时,它还使用 SQL(Structured Query Language,结构化查询语言)对数据进行操作。

传统的关系型数据库采用表格的存储方式,数据以行和列的方式进行存储,要读取和查询都十分方便。

🎏代表: Oracle Database、SQL Server、DB2、PostgreSQL 和MySQL。

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

文档型数据库的灵感来自于 Lotus Notes 办公软件,和最后一种键值存储数据库类似。文档型数据库可以看作是键值数据库的升级版,允许之间嵌套键值。而且文档型数据库比键值数据库的查询效率更高。

面向文档数据库会将数据以文档的形式存储。每个文档都是一系列数据项的集合。每个数据项都有一个名称与对应的值,值既可以是简单的数据类型,如字符串、数字和日期等;也可以是复杂的类型,如有序列表和关联对象。

数据存储的最小单位是文档,同一个表中存储的文档属性可以是不同的,数据可以使用XML、JSON或者JSONB等多种形式存储。

🎏代表: MongDB 和 CouchDB。

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

列存储数据库将数据存储存在列族(column family)中,一个列族用来存储经常被一起查询的相关数据。例如,如果有一个 Person 类,我们经常会一起查询他们的姓名和年龄而不是薪资。这种情况下,姓名和年龄就会被放入一个列族中,而薪资则在另一个列族中。

🎏代表: Cassandra 和 HBase。

🌿 XML 数据库(XML Database,XMLDB)

XML 数据库是一种支持对 XML(标准通用标记语言下的一个应用)格式文档进行存储和查询等操作的数据管理系统。在系统中,开发人员可以对数据库中的 XML 文档进行查询、导出和指定格式的序列化。

🌿键值存储数据库(Key-Value Store,KVS)

键值存储数据库是用来保存查询所使用的==主键(Key)和值(Value)==的组合的数据库。具有编程语言知识的读者可以把它想象成关联数组或者散列(hash)。

近年来,随着键值存储数据库被应用到 Google 等需要对大量数据进行超高速查询的 Web 服务当中,它正逐渐为人们所关注。

🎏代表:Redis、Memcached 和 MemcachedDB。

🔻五、数据库有关术语

💦数据库: 数据库是一些关联表的集合

💦数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。

💦列: 一列(数据元素) 包含了相同类型的数据, 例如邮政编码的数据。

💦行:一行(元组,或记录)是一组相关的数据,例如一条用户订阅的数据。

💦冗余:存储两倍数据,冗余降低了性能,但提高了数据的安全性

💦主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。

💦外键:外键用于关联两个表

💦复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引

💦索引:使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构。类似于书籍的目录。

💦参照完整性: 参照的完整性要求关系中不允许引用不存在的实体。与实体完整性是关系模型必须满足的完整性约束条件,目的是保证数据的一致性

🔻六、常见DBMS排名

数据库排名:https://db-engines.com/en/ranking

在这里插入图片描述
在这里插入图片描述

🔻七、常见数据库介绍

7.1 RDS(关系型数据库)

  • 🍹 MySQL

MySQL 是最流行的关系型数据库管理系统之一,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。
MySQL6.X之后采用了双授权政策,分为社区版和商业版,特点:体积小、速度快、总体拥有成本低、开源、可定制,一般中小型和大型网站的开发都选择 MySQL 作为网站数据库。

  • 🍹 MariaDB

是MySQL的一个分支,视为开源数据库MySQL的替代品。主要由开源社区在维护,由MySQL的创始人Michael Widenius主导开发,MariaDB名称来自Michael Widenius的女儿Maria的名字。

  • 🍹 PostgreSQL

PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),是以加州大学计算机系开发的POSTGRES 4.2版本为基础的对象关系型数据库管理系统。

PostgreSQL,也称为 Postgres,支持非关系和关系数据类型。它被称为当今可用的最兼容、最稳定和最成熟的关系数据库之一,并且可以轻松处理复杂的查询。

  • 🍹 SQL Server

SQL Server是大型企业软件的首选平台,主要面向使用.NET作为开发语言的开发人员,以前只能在Windows上运行,微软在2022年 3 月对外宣布了 Linux 版的 SQL Server。

  • **🍹 Oracle **

是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小微机环境。它是一种高效率的、可靠性好的、适应高吞吐量的数据库方案。

7.2 NoSQL(Not Only SQL)——非关系型数据库

  • 🍹 Redis

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

Redis的特点:单线程,基于内存,丰富的数据结构,支持持久化,分布式锁,简单事务

使用的场景包括:

1.缓存
2.点赞,签到,打卡
3.排行榜
4.消息队列
5.限流

  • 🍹 Memcached

memcached是一套分布式的高速缓存系统,由LiveJournal的Brad Fitzpatrick开发,与redis相似。

特点:协议简单、基于libevent的事件处理、内置内存存储方式、memcached不互相通信的分布式。

7.3 面向文档数据库

  • 🍹 MongoDB

MongoDB是一个基于分布式文件存储 [1] 的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。

特点:高性能、易部署、易使用,存储数据非常方便。

  • 🍹 CouchDB

CouchDB是用Erlang开发的面向文档的数据库系统,2010年7月14日发布了1.0版本。

其数据存储方式有点类似lucene的index文件格式,CouchDB最大的意义在于它是一个面向web应用的新一代存储系统。

7.4 列式存储

列式数据库是以列相关存储架构进行数据存储的数据库,主要适合于批量数据处理和即时查询。相对应的是行式数据库,数据以行相关的存储体系架构进行空间分配,主要适合于大批量的数据处理,常用于联机事务型数据处理。

  • 🍹 Hbase

HBase是一个分布式的、面向列的开源数据库,是Apache的Hadoop项目的子项目。HBase不同于一般的关系数据库,它是一个适合于非结构化数据存储的数据库。另一个不同的是HBase基于列的而不是基于行的模式。

7.5 图数据库

  • 🍹 GDB

GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。

7.6 搜索引擎数据库

  • 🍹 Solr

Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口。用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引;也可以通过Http Get操作提出查找请求,并得到XML格式的返回结果。

  • 🍹 Elasticsearch

Elasticsearch 是一个分布式、高扩展、高实时的搜索与数据分析引擎。它能很方便的使大量数据具有搜索、分析和探索的能力。充分利用Elasticsearch的水平伸缩性,能使数据在生产环境变得更有价值。

Elasticsearch 的实现原理主要分为以下几个步骤,首先用户将数据提交到Elasticsearch 数据库中,再通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据,当用户搜索数据时候,再根据权重将结果排名,打分,再将返回结果呈现给用户。

🔻八、总结—温故知新

❓ 什么是数据库,数据库产生及背景
❓ 数据库种类有哪些
❓ 数据库有关术语
❓ 常见数据库特点及使用场景

👈【上一篇】
--💖The End💖 点点关注,收藏不迷路💖--
【下一篇】👉

http://www.ppmy.cn/news/239011.html

相关文章

快手 Flink 的稳定性和功能性扩展

摘要:本文整理自快手技术专家刘建刚,在 Flink Forward Asia 2022 生产实践专场的分享。本篇内容主要分为四个部分: 1. 快手 Flink 平台 2. 稳定性保障和智能运维 3. 复杂场景下的功能扩展 4. 批处理的定制优化 Tips:点击「阅读原文…

华为MateBook D (MRC-WX0)笔记本电脑安装Win7系统

一小朋友,2018年买了华为 MateBook D 笔记本电脑,开始一直使用Win10系统,最近心血来潮想换Win7系统。 自己的电脑自己决定! 我看了下配置,Intel i3-7020U的处理器。 7代。 那么,我来装了一下&#xff0c…

如何进行物联网开发可以快速完成产品研发?

物联网产品的研发与开发过程,是一个不断探索、创新、实践的过程,需要很长的周期,在这个过程中,项目团队往往需要投入大量的人力、物力和时间。同时,物联网产品研发过程中还涉及到大量的专业技术和知识,需要…

华为手机无线投屏到win10笔记本电脑

1、win10笔记本电脑设置 (1)开始菜单–>设置,进入Windows设置 (2)单击“系统”,进入系统设置页面 (3)选择投影到此电脑 2、华为手机设置 (1)与笔记本…

佳能90D和7D3估计是同一台单反相机 80D成绝唱

本文来自太平洋电脑网 最近佳能EOS RP的发布,8999元的机身价非常吸引人。在单反的研发上,佳能也不敢怠慢,不过有外媒猜测佳能90D和7D3会合并成一台单反,定位则是APS-C画幅上比较高端的机型。 另外在今年NAB上,佳能将会…

华为笔记本电脑怎么重装Win10系统

华为笔记本电脑怎么重装Win10系统呢?最近总是有一些网友来询问这个问题,今天系统之家小编就来给朋友们解答,介绍一种比较简单的方法,那就是使用一键重装系统工具,这里推荐系统之家的装机工具,咱们一起来看看…

展豪说 41-80d

41文章:《实践丨分布式事务解决方案汇总:2PC、消息中间件、TCC、状态机重试幂等》 链接:https://mp.weixin.qq.com/s/7u5zfrLzk38tDwOfDEkuqw 点评:本文总结了解决分布式事务问题多种方案,是已读过分布式事务技术文章中…

办公效率提升200%,新款华为笔记本真香!送一台

送礼进行时!为反馈广大读者粉丝们的大力支持,本号主特地选了这款 华为笔记本电脑 Magic book! 作为抽奖礼品,帮你提升工作效率。听说鸿蒙已经开源了,赶紧支持一下国货之光 最后感谢粉丝们一直支持我,希望这…