MySQL 数据库的基础知识
作者:吞吞吐吐大魔王 发布时间:2024-01-17 03:05:52
1. 认识数据库
1.1 数据库和数据结构的关系
数据结构:
是指相互之间存在一种或多种特定关系的数据元素的集合,是一个抽象的学科
我们熟知的数据结构有:
顺序表、链表、栈、队列、二叉树、哈希表…
数据库:
和数据结构不同,它是一类更具体的可以管理数据的软件。但是实现数据库的这个软件,需要用到很多的数据结构
而使用数据库管理数据具体的功能就包括:
描述:描述一条数据如何表示
组织:如何将很多数据进行汇总
至于管理的目的就是:
为了增删改查
1.2 为什么需要数据库
数据库要将数据进行管理的前提就是将数据进行存储。但是存储数据使用文件就可以了,为什么还要弄个数据库呢?
因为使用文件保存数据有以下几个缺点:
文件的安全性问题
文件不利于数据查询和管理
文件不利于存储海量数据
文件在程序中控制不方便
1.3 数据库的存储
当下绝大部分计算机都遵守着冯诺依曼体系结构
数据的存储一般放在内存储器和外存储器(外存储器包括:硬盘、光盘、U盘、软盘等,但这里指硬盘)
数据库是有多种的,并没有统一规定所有数据库存放的位置,但主要的数据库的数据存储位置如下:
大部分数据库是把数据组织在外存储上,如:
MySQL
、Oracle
、SQL Server
少数数据库是把数据组织到内存上,如:
Redis
补充: MySQL 为什么要把数据存储在外存储器(硬盘)中呢?这里我们就要先了解下内存和硬盘的区别
区别 | 内存 | 外存(硬盘) |
---|---|---|
1 | 内存的访问速度快 | 硬盘的访问速度慢 |
2 | 内存的空间小 | 硬盘的空间大 |
3 | 内存贵 | 硬盘便宜 |
4 | 如果掉电,内存上的数据会丢失 | 如果掉电,硬盘的数据不会丢失 |
综合以上2、3、4的区别,认为 MySQL 使用硬盘来存储数据更好
2. SQL
2.1 介绍
结构化查询语言(Structured Query Language
)简称 SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统
注意: SQL 和 MySQL 的区别
SQL 是一种编程语言
MySQL 是一种软件,它属于关系型数据库的一种,而关系型数据库都是支持 SQL 的,而非关系型数据库有的支持,有的不支持 SQL
2.2 分类
SQL 可以分为6部分:
数据查询语言(
DQL
): 其语句也称为“数据检索语句”,用以从表中获得数据,确定数据怎样在应用程序给出。数据操作语言(
DML
): 其语句包括动词INSERT
、UPDATE
和DELETE
。它们分别用于添加、修改和删除。事务控制语言(
TCL
): 它的语句能确保被 DML 语句影响的表的所有行及时得以更新。包括COMMIT(提交)命令、SAVEPOINT
(保存点)命令、ROLLBACK(回滚)命令。数据控制语言(
DCL
): 它的语句通过 GRANT 或 REVOKE 实现权限控制,确定单个用户和用户组对数据库对象的访问。某些RDBMS
可用 GRANT 或 REVOKE 控制对表单个列的访问。数据定义语言(
DDL
): 其语句包括动词 CREATE、ALTER 和 DROP。在数据库中创建新表或修改、删除表(CREATE TABLE 或 DROP TABLE)、为表加入索引等。指针控制语言(CCL): 它的语句,像
DECLARE CURSOR
、FETCH INTO
和UPDATE WHERE CURRENT
用于对一个或多个表单独行的操作。
3. 数据库的类别
数据库大体可以分为:
关系型数据库
非关系型数据库
3.1 关系型数据库
介绍:
是指采用了关系模型来组织数据的数据库。简单来说,关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表格及其之间的联系所组成的一个数据组织
关系型数据库都基于标准的 SQL,只是内部的一些实现有区别
常见关系型数据库:
Oracle
:甲骨文产品,是数据库中的王者。由于收费,且随着数据量的增大对机器要求比较高,所以使用成本很高。适用于银行这类对数据的安全和服务要求很高且本身很有钱的公司MySQL
:被甲骨文收购,开源免费。现在很多公司普遍使用它SQL Server
:微软产品,由于曾经这个数据库和 windows server
系统进行了捆绑,而大多数服务器系统都是在 Linux 上,所以逐渐失去市场。如今可以支持 Linux
3.2 非关系型数据库
介绍:
非关系型数据库一般指 NoSQL
,区别于关系数据库,它们不保证关系数据的 ACID 特性,都是去掉关系数据库的关系型特性
不规定基于 SQL 实现
常见非关系型数据库:
redis
:基于键值对(key-value)mongodb
:基于列族hbase
:基于文档型
3.3 区别
区别 | 关系型数据库 | 非关系型数据库 |
---|---|---|
使用 SQL | 是 | 不强制要求,一般不基于 SQL 实现 |
事务支持 | 支持 | 不支持 |
复杂操作 | 支持 | 不支持 |
海量读写操作 | 效率低 | 效率高 |
基本结构 | 基于表和列,结构固定 | 灵活性比较高 |
使用场景 | 业务方面的 OLTP 系统 | 用于数据的缓存或基于统计分析的 OLAP 系统 |
补充:
OLTP(On-Line Transaction Processing):
是指联机事物处理OLAP(On-Line Analytical Processing):
是指联机分析处理
4. MySQL 的程序结构
MySQL
其实是一个“客户端-服务器”结构的程序
那么什么是客户端和服务器呢?下面将简单介绍
4.1 客户端和服务器
介绍:
客户端:是主动发起请求的一方
服务器:是被动接受请求的一方
客户端给服务器发送的数据,称为:请求(
Request
)服务器给客户端返回的数据,称为:响应(
Response
)一个服务器同时可能给多个客户端提供服务
大部分客户端服务器都是这种“一个请求一个响应”的交互模型
客户端和服务器是通过网络来通信的
示例:
你去饭店吃饭,你跟老板说来一碗农家一碗香,后面老板给你把你点的餐端上来。
此时你就是“客户端”,饭店老板就是”服务器“,你跟老板点餐就是你的”请求“,老板把你点的餐端上来就是”响应“。而一个老板其实可以服务多个客户。
4.2 MySQL 的客户端-服务器结构
当我们使用 MySQL 时,我们其实会遇见以下几种情况:
在同一台主机安装
MySQL
客户端和 MySQL 服务器(我们自己在个人电脑安装时就是这种情况)
MySQL 客户端和
MySQL
服务器分别在两台不同的主机上
实际工作中往往是下面这种情况,多台主机的客户端连接一台主机的服务器
注意:
MySQL 是把数据存储在服务器上,服务器才是数据库的本体,负责管理数据
MySQL 客户端其实就是一个非常简单的程序,仅仅是用来和用户交互的。这个程序可能是:命令行程序、可视化界面的程序、自己代码实现的程序
4.3 MySQL 服务器
介绍:
MySQL 服务器其实含有若干个数据库(每个数据库视为是一组逻辑上的集合)
一个数据库包含了若干个有关联的表
一个表包含了若干行(每一行都有若干条记录)
一行包含了若干列(每一列都有具体的类型要求)
示例:
假如有一个 MySQL 服务器存储着 CSDN 的数据,它里面可能有3个数据库。数据库1存储着:用户信息、用户排名、文章数量等数据。数据库2存储着:活动内容、投稿文章、奖品信息等数据。数据库2存储着:视频、资源等数据。而其中数据库1中的例如用户信息等数据,它其实就是一个表,类似于 excel 表,而有关联的几个表,就组成了一个数据库。
注意:
数据库的含义其实要依照上下文,它可能是一门学科,也可能是一类软件,有时也指一个服务器,有时还表示一个数据集合等
来源:https://blog.csdn.net/weixin_51367845/article/details/121299480


猜你喜欢
- CocosCreator版本:2.3.4cocos没有List组件,所以要自己写。从cocos的example项目中找到assets/cas
- 详解java调用ffmpeg转换视频格式为flv注意:下面的程序是在Linux下运行的,如果在windows下rmvb转换成avi会出现问题
- MySQL字符串的拼接、截取、替换、查找位置。常用的字符串函数:函数说明CONCAT(s1,s2,...)返回连接参数产生的字符串,一个或多
- 数组:【重点1】implode(分隔,arr) 把数组值数据按指定字符连接起来例如:$arr=array('1','
- 题目描述1046. 最后一块石头的重量 - 力扣(LeetCode)有一堆石头,每块石头的重量都是正整数。每一回合,从中选出两块 最重的 石
- 本文实例讲述了Python面向对象之静态属性、类方法与静态方法。分享给大家供大家参考,具体如下:1. 静态属性:在函数前加@property
- 如图所示,要处理的数据是一个json数组,而且非常大下图为电脑配置,使用 json.load() 方法加载上述json文件电脑直接卡死解决思
- 最近终于找到一个好的方法,使用Python的OpenCV模块识别滑动验证码的缺口,可以将滑动验证码中的缺口识别出来了。 测试使用如
- 前言如果你认为深度学习非常的吃GPU,或者说非常的耗时间,训练一个模型要非常久,但是你如果了解了迁移学习那你的模型可能只需要几分钟,而且准确
- 1、Dreamweaver中的复制我在网页中复制的文字,粘贴到Dreamweaver中时,它总是带有原来网页的格式,请问如何只复制其中的文本
- 出差到了中国雅虎,这里的风格和淘宝很不一样。和雅虎一比,淘宝的办公环境就是个菜市场,闹哄哄,到处是人,在走道里狂奔乱窜,在每个会议室争得面红
- 我们将在下面的例子中使用这个 XML 文档。<?xml version="1.0" encod
- 方法1: 用file_get_contents 以get方式获取内容:<?php$url='https://www.aspxh
- Azkaban是什么?Azkaban是由Linkedin公司推出的一个批量工作流任务调度器,主要用于在一个工作流内以一个特定的顺
- 不废话,直接上代码Python3.6签到代码,只需修改url,账号,密码即可,此处是登录时无验证登录,有验证码的自行补充# -*- codi
- js调试工具推荐firefox的firebug插件能够给js设置断点执行能够运行时修改css样式查看dom模型等☆IE8自带的develop
- 描述:下午快下班的时候公司供应链部门的同事跑过来问我能不能以程序的方法帮他解决一些excel表格每周都需要手工重复做的事情,Excel 是数
- 步骤如下:1.图片灰化;2.中值滤波 去噪3.求图片的光影(自动光学检测)4.除法去光影5.阈值操作6.实现了三种目标检测方法主要分两种连通
- 最近做一个的GUI,因为调用了os模块里的system方法,使用pyinstaller打包的时候选择不输出系统命令弹框,程序无法运行,要求要
- 你们要的3D太阳系图片上传之后不知为何帧率降低了许多。。。日地月三体所谓三体,就是三个物体在重力作用下的运动。由于三点共面,所以三个质点仅在