[012-001].第1节:数据库概述

MySQL学习大纲

我的数据库学习大纲


1. 什么是数据的持久化:

  • 1.之所以学习数据库是因为可以实现数据的持久化存储,持久化的意思就是把数据保存到可掉电式存储设备中以供之后使用。大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以“固化”,而持久化的实现过程大多通过各种关系数据库来完成,当然也可以存储在磁盘文件、XML数据文件中
    在这里插入图片描述

2. 数据库与数据库管理系统

2.1.数据库的相关概念

  • DB:数据库(Database)
    • 即存储数据的“仓库”,其本质是一个文件系统。它保存了一系列有组织的数据。
  • DBMS:数据库管理系统(Database Management System)
    • 是一种操纵和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制。用户通过数据库管理系统访问数据库中表内的数据。
  • SQL:结构化查询语言(Structured Query Language)
    • 专门用来与数据库通信的语言。

2.2. 数据库与数据库管理系统的关系

  • 1.数据库管理系统可以管理多个数据库,一般开发人员会会针对每一个应用创建一个数据库。为保存应用中的实体数据,一般会在数据库创建多个表,保存程序中实体用户的数据。
  • 2.数据库管理系统、数据库和表的关系如下所示:
    在这里插入图片描述
    在这里插入图片描述

2.3.常见的数据库介绍

  • 1.Oracle:
    • 1979 年,Oracle 2 诞生,它是第一个商用的 RDBMS(关系型数据库管理系统)。随着 Oracle 软件的名气越来越大,公司也改名叫 Oracle 公司。
    • 2007年,总计85亿美金收购BEA Systems。
    • 2009年,总计74亿美金收购SUN。此前的2008年,SUN以10亿美金收购MySQL。意味着Oracle 同时拥有了MySQL 的管理权,至此 Oracle 在数据库领域中成为绝对的领导者。
    • 2013年,甲骨文超越IBM,成为继Microsoft后全球第二大软件公司。
    • 如今 Oracle 的年收入达到了 400 亿美金,足以证明商用(收费)数据库软件的价值。
  • 2.SQL Server
    • SQL Server 是微软开发的大型商业数据库,诞生于 1989 年。C#、.net等语言常使用,与WinNT完全集成,也可以很好地与Microsoft BackOffice产品集成。
  • 3.DB2
    • IBM公司的数据库产品,收费的。常应用在银行系统中。
  • 4.PostgreSQL:
    • PostgreSQL 的稳定性极强,最符合SQL标准,开放源码,具备商业级DBMS质量。PG对数据量大的文本以及SQL处理较快
  • 5.SQLite
    • 嵌入式的小型数据库,应用在手机端。 零配置,SQlite3不用安装,不用配置,不用启动,关闭或者配置数据库实例。当系统崩溃后不用做任何恢复操作,再下次使用数据库的时候自动恢复。
  • 6.informix
    • IBM公司出品,取自Information 和Unix的结合,它是第一个被移植到Linux上的商业数据库产品。仅运行于unix/linux平台,命令行操作。 性能较高,支持集群,适应于安全性要求极高的系统,尤其是银行,证券系统的应用。

3.关系型数据库与非关系型数据库:

3.1.关系型数据库(RDBMS)

a.实质

  • 1.这种类型的数据库是最古老的数据库类型,关系型数据库模型是把复杂的数据结构归结为简单的二元关系 (即二维表格形式)
    在这里插入图片描述
  • 2.关系型数据库以行(row)列(column)的形式存储数据,以便于用户理解。这一系列的行和列被称为表(table),一组表组成了一个库(database)
  • 3.SQL就是关系型数据库的查询语言
    在这里插入图片描述

b.优势

  • 1.复杂查询可以用SQL语句方便的在一个表以及多个表之间做非常复杂的数据查询。
  • 2.事务支持使得对于安全性能很高的数据访问要求得以实现。

3.2.非关系型数据库(非RDBMS)

a.非关系型数据库介绍:

  • 非关系型数据库,可看成传统关系型数据库的功能阉割版本基于键值对存储数据,不需要经过SQL层的解析,性能非常高。同时,通过减少不常用的功能,进一步提高性能。

4.3.有哪些非关系型数据库

.NoSQL 泛指非关系型数据库,包括了榜单上的键值型数据库、文档型数据库、搜索引擎和列存储、图形数据库等。

  • 1.键值型数据库:Redis :键值型数据库典型的使用场景是作为 内存缓存 。 Redis 是最流行的键值型数据库

  • 2.文档型数据库: MongoDBCouchDB

    • 此类数据库可存放并获取文档,可以是XML、JSON等格式。
    • 在数据库中文档作为处理信息的基本单位,一个文档就相当于一条记录。文档数据库所存放的文档,就相当于键值数据库所存放的“值”。
  • 3.搜索引擎数据库Solr、Elasticsearch、Splunk

    • 虽然关系型数据库采用了索引提升检索效率,但是针对全文索引效率却较低。搜索引擎数据库是应用在搜索引擎领域的数据存储形式,由于搜索引擎会爬取大量的数据,并以特定的格式进行存储,这样在检索的时候才能保证性能最优。核心原理是“倒排索引”
  • 4.列式数据库HBase

    • 列式数据库是相对于行式存储的数据库,Oracle、MySQL、SQL Server 等数据库都是采用的行式存储(Row-based),而列式数据库是将数据按照列存储到数据库中,这样做的好处是可以大量降低系统的I/O,适合于分布式文件系统,不足在于功能相对有限。
      在这里插入图片描述
  • 5.图形数据库Neo4J、InfoGrid

    • 图形数据库顾名思义,就是一种存储图形关系的数据库。它利用了图这种数据结构存储了实体(对象)之间的关系
    • 关系型数据用于存储明确关系的数据,但对于复杂关系的数据存储却有些力不从心。如社交网络中人物之间的关系,如果用关系型数据库则非常复杂,用图形数据库将非常简单
      在这里插入图片描述

4.表与表的关联关系

  • 1.表与表之间的数据记录有关系(relationship)。现实世界中的各种实体以及实体之间的各种联系均用关系模型来表示。有四种关系,分别是一对一关联、一对多关联、多对多关联、自我引用

4.1.一对一关联(one-to-one)

  • 1.在实际的开发中应用不多,因为一对一可以创建成一张表。
  • 2.举例:设计 学生表 :学号、姓名、手机号码、班级、系别、身份证号码、家庭住址、籍贯、紧急联系人、…
    • 拆为两个表:两个表的记录是一一对应关系。
    • 基础信息表 (常用信息):学号、姓名、手机号码、班级、系别
    • 档案信息表 (不常用信息):学号、身份证号码、家庭住址、籍贯、紧急联系人、…
  • 3.两种建表原则:
    • 外键唯一:主表的主键和从表的外键(唯一),形成主外键关系,外键唯一
    • 外键是主键:主表的主键和从表的主键,形成主外键关系
      在这里插入图片描述

4.2. 一对多关系(one-to-many)

  • 1.常见实例场景: 客户表和订单表 , 分类表和商品表 , 部门表和员工表
  • 2.举例(一个员工对应一个部门,一个部门对应多个员工):
    • 员工表:编号、姓名、…、所属部门
    • 部门表:编号、名称、简介
  • 3.一对多建表原则:在从表(多方)创建一个字段,字段作为外键指向主表(一方)的主键,根据上述例子,主表是部门表,从表是员工表
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

4.3.多对多(many-to-many)关系:

  • 1.要表示多对多关系必须创建第三个表,该表通常称为 联接表 ,它将多对多关系划分为两个一对多关系。将这两个表的主键都插入到第三个表中
    在这里插入图片描述

  • 2.举例1:学生-课程

    • 学生信息表 :一行代表一个学生的信息(学号、姓名、手机号码、班级、系别…)
    • 课程信息表:一行代表一个课程信息(课程编号,授课老师等)
    • 选课信息表:一个学生可以选择多门课,一个课程可以多个学生选择
  • 3.举例2:产品-订单

    • “订单”表和“产品”表有一种多对多的关系,这种关系是通过与“订单明细”表建立两个定义的。一个订单可以有多个产品,每个产品可以出现在多个订单中。
    • 产品表 :“产品”表中的每条记录表示一个产品。
    • 订单表 :“订单”表中的每条记录表示一个订单。
    • 订单明细表 :每个产品可以与“订单”表中的多条记录对应,即出现在多个订单中。一个订单可以与“产品”表中的多条记录对应,即包含多个产品。
      在这里插入图片描述
  • 3.举例3:用户-角色:

    • 多对多关系建表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键
      在这里插入图片描述

4.4.自我引用(Self reference):关系

在这里插入图片描述


5.关系型数据库-MySQL介绍:

5.1.概述:

  • 1.MySQL是一个 开放源代码的关系型数据库管理系统
  • 2.MySQL6.x 版本之后分为 社区版 和 商业版 。
  • 3.MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
  • 4.MySQL支持大型的数据库。可以处理拥有上千万条记录的大型数据库
  • 5.MySQL支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持 4GB ,64位系统支持最大的表文件为 8TB
  • 6.MySQL使用 标准的SQL数据语言 形式。
  • 7.MySQL可以允许运行于多个系统上,并且支持多种语言。这些编程语言包括C、C++、Python、Java、Perl、PHP和Ruby等。

5.2.关于MySQL 8.0

  • 1.MySQL从5.7版本直接跳跃发布了8.0版本 ,这是一个令人兴奋的里程碑版本
  • 2.MySQL 8版本在功能上做了显著的改进与增强,开发者对MySQL的源代码进行了重构,最突出的一点是多MySQL Optimizer优化器进行了改进。不仅在速度上得到了改善,还为用户带来了更好的性能和更棒的体验。

5.3.Oracle vs MySQL

  • 1.Oracle 更适合大型跨国企业的使用,因为他们对费用不敏感,但是对性能要求以及安全性有更高的要求。
  • 2.MySQL 由于其体积小、速度快、总体拥有成本低,可处理上千万条记录的大型数据库,尤其是开放源码这一特点,使得很多互联网公司、中小型网站选择了MySQL作为网站数据库(Facebook,Twitter,YouTube,阿里巴巴/蚂蚁金服,去哪儿,美团外卖,腾讯)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值