博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mysql初识数据库《二》数据库管理软件的由来
阅读量:5281 次
发布时间:2019-06-14

本文共 854 字,大约阅读时间需要 2 分钟。

数据库管理软件的由来

基于我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问,一个文件仅仅只能存在于某一台机器上。

如果我们暂且忽略直接基于文件来存取数据的效率问题,并且假设程序所有的组件都运行在一台机器上,那么用文件存取数据,并没有问题。

很不幸,这些假设都是你自己意淫出来的,上述假设存在以下几个问题。。。。。。

1、程序所有的组件就不可能运行在一台机器上

因为这台机器一旦挂掉则意味着整个软件的崩溃,并且程序的执行效率依赖于承载它的硬件,而一台机器机器的性能总归是有限的,受限于目前的硬件水平,就一台机器的性能垂直进行扩展是有极限的。于是我们只能通过水平扩展来增强我们系统的整体性能,这就需要我们将程序的各个组件分布于多台机器去执行。

2、数据安全问题

根据1的描述,我们将程序的各个组件分布到各台机器,但需知各组件仍然是一个整体,言外之意,所有组件的数据还是要共享的。但每台机器上的组件都只能操作本机的文件,这就导致了数据必然不一致。于是我们想到了将数据与应用程序分离:把文件存放于一台机器,然后将多台机器通过网络去访问这台机器上的文件(用socket实现),即共享这台机器上的文件,共享则意味着竞争,会发生数据不安全,需要加锁处理。。。。

3、并发

根据2的描述,我们必须写一个socket服务端来管理这台机器(数据库服务器)上的文件,然后写一个socket客户端,完成如下功能:

1.远程连接(支持并发)2.打开文件3.读写(加锁)4.关闭文件

总结:

我们在编写任何程序之前,都需要事先写好基于网络操作一台主机上文件的程序(socket服务端与客户端程序),于是有人将此类程序写成一个专门的处理软件,这就是mysql等数据库管理软件的由来,但mysql解决的不仅仅是数据共享的问题,还有查询效率,安全性等一系列问题,总之,把程序员从数据管理中解脱出来,专注于自己的程序逻辑的编写。

转载于:https://www.cnblogs.com/sunny666/p/10012468.html

你可能感兴趣的文章
Ruby on Rails Session 1: How to Build a Ruby on Rails on the Ubuntu.
查看>>
获取中国时区时间
查看>>
[BZOJ 3626] [LNOI2014] LCA 【树链剖分 + 离线 + 差分询问】
查看>>
zabbix实现163邮件报警
查看>>
根据UIView获取其UIViewController
查看>>
JMeter录制脚本方式(二)
查看>>
ccnet
查看>>
Windows下使用notepad++对文本进行行列转换
查看>>
何为java中常说的封装、继承、多态
查看>>
字符串操作20160526
查看>>
设计模式之代理模式20170724
查看>>
dll引用wcf服务后,第三方调用dll时无法发现终结点的解决方法
查看>>
MATLAB 添加自定义的模块到simulink库浏览器
查看>>
C语言最后一次作业--总结报告
查看>>
30255Java_5.5 GUI
查看>>
PID控制器开发笔记之三:抗积分饱和PID控制器的实现
查看>>
.net 实现 一二级分类
查看>>
Django 中间件
查看>>
Linux常用命令入门文件、网络、系统及其他操作命令
查看>>
Atitit.Java exe bat 作为windows系统服务程序运行
查看>>