开发者社区> 余二五> 正文

mysql数据库-简述

简介:
+关注继续查看

一、数据库分类

说明:mysql 适合中小企业,开源、灵活、具有代表性;DB2、oracle适合大型企业;达梦数据库属于国内


二、文件系统管理数据存在的问题

1. 数据的冗余性和不一致性

如果没有数据库,那么所有的服务器都需要存一份数据;而且每一份数据需实时一致

2. 数据访问

数据会越来越大,如果没有数据库,搜索数据缓慢

3. 数据相对独立

不同类型的文件,保存格式不同,如果拷贝给第三方,需要对应的应用程序

4. 完整性和原子性问题

存储文件时突然中断,会导致损失

5. 并发访问异常问题

2个用户同时访问一个文件,删掉前十行,另一个客户访问时,给不给他看

6.  安全性问题

设置文件被哪些用户访问,访问某些行,文件中的一部分,读写执行做不到


数据库,指的是以一定方式存储在一起、能为多个用户共享、具有尽可能小的冗余度的特点、是与应用程序彼此独立的数据集合,实现:

  • 数据共享

  • 减少数据的冗余度

  • 数据实现集中控制

  • 数据的一致性

  • 故障恢复


三、模型

1. 层次模型:也是树状模型;缺点:随着数据量的增多,会出现大量的数量冗余


2. 网状模型:解决了树状模型的数据冗余,缺点:网络太多,不便于维护


3. 关系模型:使用行和列作为基础,建立关系表,被广泛采用

说明:由于关系模型的出现,原来的数据库管理系统DBMS,衍生成关系数据库管理系统RDBMS,行业也默认将两者划成等号(实际为子系统):DBMS=RDBMS


4. E-R模型:ERM概念,实体关系建模(创建数据库的思路和步骤)

联系:一个或多个实体之间的关系

属性:实体的某一特性


四、操作数据库

1. sql语句

数据操作语言(DML):用于操作数据库对象中包含的数据。例如insert,update,delete

数据定义语言(DDL):用户定义和管理数据对象,包括数据库,表等。例如create,drop,alter

数据查询语言(DQL):用于查询数据库对象中包含的数据。例如select

数据控制语言(DCL):用于管理数据库的语言,包括管理权限以及数据更改。例如grant,revoke


2. 逻辑关系

文件系统的逻辑关系:

上层   :文件系统中的数据,文件

底层   :硬盘中的数据块

中间层:文件系统,将数据块以文件形式呈现


数据库的逻辑关系:

上层   :数据表

底层   :文件,相当于文件系统的上层

中间层:能够将文件逻辑成表的组件,即存储引擎,如MyISAM,InnoDB, Memory......


3. 存储引擎

说明:  Mysql支持多种存储引擎,可以根据需要灵活的选择不同的存储引擎; 而ORACLE只支持一种存储引擎,这也是mysql流行的原因之一


MyISAM最早的存储引擎,Mysql默认引擎,查询速度较快,而5.5版本以上默认为InnoDB;


缺点:

a. 不支持事务:事务,即一段sql语句的批处理,且具有原子性(要么所有语句都执行成功,要么都失败)


b. 不支持行级锁:行级锁(冲突少,但是速度慢,锁多行则需要执行多条命令),只有InnoDB支持,即锁定表中的某一行,不允许修改,同一个表中的其他行可以修改;支持表级锁(锁表速度快,但时冲突也比较多),锁定时,所有用户可以写入或者只能进行读取,不能修改;页级锁(行级锁和表级别锁折中,即锁定相邻的几行,不能跳跃),DBD存储引擎才支持


c. 不支持外键约束:域约束,即在某个位置只允许某种类型的数据限制;但是如果新建的数据符合类型,只是在对应的关系表中,没有该值定义,也不允许新建该条数据,即外键约束。主键约束、唯一性约束、检查性约束.......


InnoDB 对MyISAM的补充的一种存储引擎

Memory基于内存的存储引擎,速度快,但是不能永久保存数据,需要和MyISAM或InnoDB结合起来使用,比较特殊


五、数据库结构

1. 存储管理器

  权限以及完整性管理器组件:授予哪个客户什么权限,去执行

  事务管理器组件:一个批处理文件中的所有命令,要么全部成功,要么全部失败

  文件管理器组件:将文件和表建立起对应关系

  缓冲区管理器组件:表表较大时,缓冲表中哪部分数据


2. 查询管理器

说明:接收、理解、提交请求,给存储管理器

查询执行引擎:将理解的请求提交给存储管理器


用户请求(应用程序、管理员手动执行sql命令、第三方API接口访问、第三方工具phpmyadmin图形化访问,监听在同一个套接字上)->查询管理器->存储管理器->本地磁盘


六、数据库工作模式

说明:采用单进程多线程模式;每一个线程负责一个用户的连接

守护线程:后台默认运行,不需要跟用户进行交互的进程,比如处理完请求,从缓存中拿出数据写进存储设备

应用线程:用户连接时分配给用户,用户断开时撤销的进程


七、数据库性能优化

1. 增加缓存机制,提高用户访问速度

2. 线程重用,当用户断开访问时,不断开线程,而是把线程给其他用户使用(因为在断开、建立线程时,会消耗系统资源)

3. 结合硬件和系统的兼容性,增加内存


八、数据库短板

      SMP 对称多处理结构,一个查询语句请求只能由一个cpu来处理(框架写死了),其他cpu只能围观;如果同时有16个查询语句请求,则可以由16个cpul来处理;一般用户小企业,但是诸如淘宝之类大公司也在使用,因为用到了解决短板对应的技术,如集群、读写分离、分区分表等










本文转自 huangzp168 51CTO博客,原文链接:http://blog.51cto.com/huangzp/1895780,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
25049 0
使用OpenApi弹性释放和设置云服务器ECS释放
云服务器ECS的一个重要特性就是按需创建资源。您可以在业务高峰期按需弹性的自定义规则进行资源创建,在完成业务计算的时候释放资源。本篇将提供几个Tips帮助您更加容易和自动化的完成云服务器的释放和弹性设置。
18704 0
阿里云服务器安全组设置内网互通的方法
虽然0.0.0.0/0使用非常方便,但是发现很多同学使用它来做内网互通,这是有安全风险的,实例有可能会在经典网络被内网IP访问到。下面介绍一下四种安全的内网互联设置方法。 购买前请先:领取阿里云幸运券,有很多优惠,可到下文中领取。
19014 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
18629 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
20351 0
使用NAT网关轻松为单台云服务器设置多个公网IP
在应用中,有时会遇到用户询问如何使单台云服务器具备多个公网IP的问题。 具体如何操作呢,有了NAT网关这个也不是难题。
35083 0
使用SSH远程登录阿里云ECS服务器
远程连接服务器以及配置环境
13429 0
如何设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云安全组设置详细图文教程(收藏起来) 阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程。阿里云会要求客户设置安全组,如果不设置,阿里云会指定默认的安全组。那么,这个安全组是什么呢?顾名思义,就是为了服务器安全设置的。安全组其实就是一个虚拟的防火墙,可以让用户从端口、IP的维度来筛选对应服务器的访问者,从而形成一个云上的安全域。
17123 0
+关注
20381
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载