本文介绍: 讲师:尚硅谷-宋红康(江湖人称:康师傅)Oracle1979 年,Oracle 2 诞生,它是第一个商用的 RDBMS(关系数据库管理系统)。随着 Oracle 软件的名气越来越大,公司也改名叫 Oracle 公司。2007年,总计85亿美金收购BEA Systems。2009年,总计74亿美金收购SUN。此前的2008年,SUN以10亿美金收购MySQL。意味着Oracle 同时拥有了 MySQL 的管理权,至此 Oracle 在数据库领域成为绝对领导者。

视频链接【MySQL数据库入门到大牛,mysql安装到优化,百科全书级,全网天花板】

第01章_数据库概述

讲师:尚硅谷-宋红康(江湖人称:康师傅

官网http://www.atguigu.com


1. 为什么使用数据库

2. 数据库数据管理系统

2.1 数据库的相关概念

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

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

数据库管理系统(DBMS)可以管理个数据库,一般开发人员针对一个应用创建个数据库。为保存应用实体的数据,一般会在数据库创建多个表,以保存程序实体用户的数据。

数据库管理系统、数据库和表的关系如图所示

在这里插入图片描述

在这里插入图片描述

2.3 常见的数据库管理系统排名(DBMS)

目前互联网常见的数据库管理软件有Oracle、MySQL、MS SQL Server、DB2、PostgreSQL、Access、Sybase、Informix几种。以下是2021年DB-Engines Ranking 对各数据库受欢迎程度进行调查后的统计结果:(查看数据库最新排名:https://dbengines.com/en/ranking)

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

对应的走势图:(https://dbengines.com/en/ranking_trend

在这里插入图片描述

2.4 常见的数据库介绍

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 亿美金,足以证明商用(收费)数据库软件的价值。

SQL Server

SQL Server 是微软开发的大型商业数据库,诞生于 1989 年。C#、.net语言常使用,与WinNT完全集成,也可以很好地与Microsoft BackOffice产品集成

DB2

IBM公司的数据库产品,收费的。常应用在银行系统中。

PostgreSQL

PostgreSQL 的稳定性极强,最符合SQL标准开放源码,具备商业级DBMS质量。PG对数据量大的文本以及SQL处理较快。

SyBase

已经淡出历史舞台。提供了一个非常专业数据建模工具PowerDesigner。

SQLite

嵌入式的小型数据库,应用在手机端。 零配置,SQlite3不用安装,不用配置,不用启动关闭或者配置数据库实例。当系统崩溃后不用做任何恢复操作,再下次使用数据库的时候自动恢复

informix

IBM公司出品,取自Information 和Unix结合,它是第一个移植到Linux上的商业数据库产品。仅运行unix/linux平台命令行操作性能较高,支持集群适应安全性要求极高的系统,尤其是银行,证券系统的应用。

3. MySQL介绍

3.1 概述

3.2 MySQL发展史重大事件

MySQL的历史就是整个互联网发展史。互联网业务从社交领域电商领域金融领域发展,推动着应用对数据库的需求提升,对传统的数据库服务能力提出了挑战。高并发高性能、高可用、轻资源、易维护、易扩展的需求,促进了MySQL的长足发展

在这里插入图片描述

1.4 关于MySQL 8.0

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

1.5 Why choose MySQL?

在这里插入图片描述

为什么如此多的厂商要选用MySQL?大概总结原因主要有以下几点:

  1. 开放代码,使用成本低。

  2. 性能卓越,服务稳定

  3. 软件体积小,使用简单,并且易于维护。

  4. 历史悠久,社区用户非常活跃,遇到问题可以寻求帮助。

  5. 许多互联网公司在用,经过了时间验证

1.6 Oracle vs MySQL

Oracle 更适合大型跨国企业的使用,因为他们费用敏感,但是对性能要求以及安全性有更高的要求。

MySQL 由于其体积小、速度快、总体拥有成本低,可处理上千万条记录的大型数据库,尤其是开放源码这一特点,使得很多互联网公司、中小型网站选择了MySQL作为网站数据库(Facebook,Twitter,YouTube,阿里巴巴/蚂蚁金服,去哪儿,美团外卖腾讯)。

4. RDBMS 与 非RDBMS

从排名中我们能看出来,关系型数据库绝对是 DBMS 的主流,其中使用最多的 DBMS 分别是 Oracle、MySQL 和 SQL Server。这些都是关系型数据库(RDBMS)。

4.1 关系型数据库(RDBMS)

4.1.1 实质

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

4.1.2 优势

4.2 非关系型数据库(非RDBMS)

4.2.1 介绍

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

目前基本上大部分主流的非关系型数据库都是免费的。

4.2.2 有哪些非关系型数据库

相比于 SQL,NoSQL 泛指非关系型数据库,包括了榜单上的键值型数据库、文档型数据库、搜索引擎列存储等,除此以外还包括图形数据库。也只有用 NoSQL 一词才能将这些技术囊括进来。

键值型数据库

键值型数据库通过 Key-Value 键值方式存储数据,其中 Key 和 Value 可以是简单对象,也可以是复杂的对象。Key 作为唯一标识符,优点是查找速度快,在这方面明显优于关系型数据库,缺点是无法像关系型数据库一样使用条件过滤比如 WHERE),如果你不知道去哪里找数据,就要遍历所有的键,这就会消耗大量的计算

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

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

文档型数据库

此类数据库可存放获取文档,可以是XML、JSON等格式。在数据库中文档作为处理信息基本单位一个文档就相当于一条记录。文档数据库所存放的文档,就相当于键值数据库所存放的“值”。MongoDB 是最流行的文档型数据库。此外,还有CouchDB等。

搜索引擎数据库

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

典型产品:Solr、Elasticsearch、Splunk 等。

列式数据库

列式数据库是相对于行式存储的数据库,Oracle、MySQL、SQL Server 等数据库都是采用的行式存储(Rowbased),而列式数据库是将数据按照列存储到数据库中,这样做的好处是可以大量降低系统的 I/O,适合于分布式文件系统,不足在于功能相对有限。典型产品:HBase等。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

图形数据库

图形数据库,利用了图这种数据结构存储了实体对象之间的关系。图形数据库最典型的例子就是社交网络中人与人的关系,数据模型主要是以节点和边(关系)来实现,特点在于能高效地解决复杂的关系问题

图形数据库顾名思义,就是一种存储图形关系的数据库。它利用了图这种数据结构存储了实体对象之间的关系。关系型数据用于存储明确关系的数据,但对于复杂关系的数据存储却有些力不从心。如社交网络中人物之间的关系,如果用关系型数据库则非常复杂,用图形数据库将非常简单。典型产品:Neo4J、InfoGrid等。

4.2.3 NoSQL的演变

由于 SQL 一直称霸 DBMS,因此许多人在思考是否有一种数据库技术能远离 SQL,于是 NoSQL 诞生了,但是随着发展却发现越来越离不开 SQL。到目前为止 NoSQL 阵营中的 DBMS 都会有实现类似 SQL 的功能。下面是“NoSQL”这个名词在不同时期的诠释,从这些释义的变化中可以看出 NoSQL 功能的演变

1970:NoSQL = We have no SQL

1980:NoSQL = Know SQL

2000:NoSQL = No SQL!

2005:NoSQL = Not only SQL

2013:NoSQL = No, SQL!

NoSQL 对 SQL 做出了很好的补充,比如实际开发中,有很多业务需求,其实并不需要完整的关系型数据库功能,非关系型数据库的功能就足够使用了。这种情况下,使用性能更高成本更低的非关系型数据库当然是更明智的选择比如日志收集排行榜定时器等。

4.3 小结

NoSQL 的分类很多,即便如此,在 DBMS 排名中,还是 SQL 阵营的比重更大,影响力前 5 的 DBMS 中有 4 个是关系型数据库,而排名前 20 的 DBMS 中也有 12 个是关系型数据库。所以说,掌握 SQL 是非常有必要的。整套课程将围绕 SQL 展开

5. 关系型数据库设计规则

5.1 表、记录、字段

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

ORM思想 (Object Relational Mapping)体现:
数据库中的一个表  <---> Java或Python中的一个类
表中的一条数据  <---> 类中的一个对象(或实体)
表中的一个列  <----> 类中的一个字段、属性(field)

5.2 表的关联关系

5.2.1 一对关联one-to-one)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

5.2.2 一对多关系(one-to-many

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
在这里插入图片描述

5.2.3 多对多(many-to-many

表示多对多关系,必须创建第三个表,该表通常称为联接,它将多对多关系划分为两个一对多关系。将这两个表的主键都插入第三个表中。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

5.3.4 自我引用(Self reference)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

”表中的每条记录表示一个订单。

  • 订单明细表每个产品可以与“订单”表中的多条记录对应,即出现在多个订单中。一个订单可以与“产品”表中的多条记录对应,即包含多个产品。

原文地址:https://blog.csdn.net/qq_49274642/article/details/134794587

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_42056.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注