MySQL基础知识
MySQL经常和“数据库”连在一起读,这很轻易对新手造成误解,认为MySQL就是一个数据库,其实不是这样,MySQL是数据库的聚集,MySQL里面有很多数据库,那么数据是直接存在数据库里的吗?并不,数据库底下还有一个叫做数据表的存储单元,数据表里面才存储数据。
打个比方,好比一座大图书馆,就是MySQL,图书馆里面分南库,北库,这就是数据库,每个库里面的书都是放在书架上的,书架就是数据表,而放在书架上的很多本书,就是数据。这么说,各人应该理解了吧,以是按大小顺序排个序就应该是,MySQL>数据库>数据表>数据。
MySql数据库是开放源代码的关系型数据库。目前,它可以提供的功能有:支持sql语言、子查询、存储过程、触发器、视图、索引、事件、锁、外键束缚和影像复制等。
同Oracle 和SQL Server等大型数据库体系一样,MySql也是客户/服务器体系并且是单进程多线程架构的数据库。
MySql区别于别的数据库体系的一个重要特点是支持插入式存储引擎。
那么什么是存储引擎呢?
存储引擎说白了就是如何存储数据、如何为存储的数据创建索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,以是存储引擎也可以称为表类型(即存储和操纵此表的类型)。
在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。 而MySql数据库提供了多种存储引擎。用户可以根据差别的需求为数据表选择差别的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。
MySql中有哪些存储引擎?
这种引擎又可以分为静态MyISAM、动态MyISAM 和压缩MyISAM三种:
- 静态MyISAM:如果数据表中的各数据列的长度都是预先固定好的,服务器将主动选择这种表类型。因为数据表中每一条记录所占用的空间都是一样的,以是这种表存取和更新的效率非常高。当数据受损时,恢复工作也比较轻易做。
- 动态MyISAM:如果数据表中出现varchar、xxxtext或xxxBLOB字段时,服务器将主动选择这种表类型。相对于静态MyISAM,这种表存储空间比较小,但由于每条记录的长度不一,以是多次修改数据后,数据表中的数据就大概离散的存储在内存中,进而导致执行效率降落。同时,内存中也大概会出现很多碎片。因此,这种类型的表要经常用optimize table 下令或优化工具来进行碎片整理。
- 压缩MyISAM:以上说到的两种类型的表都可以用myisamchk工具压缩。这种类型的表进一步减小了占用的存储,但是这种表压缩之后不能再被修改。别的,因为是压缩数据,以是这种表在读取的时候要先时行解压缩。
但是,不管是何种MyISAM表,目前它都不支持事件,行级锁和外键束缚的功能。
- MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。
归并表是将几个相同的MyISAM表归并为一个虚表。常应用于日记和数据仓库。
- InnoDB: InnoDB表类型可以看作是对MyISAM的进一步更新产品,它提供了事件、行级锁机制和外键束缚的功能。
- memory(heap): 这种类型的数据表只存在于内存中。
它利用散列索引,以是数据的存取速度非常快。 因为是存在于内存中,以是这种类型常应用于暂时表中。
- archive: 这种类型只支持select 和 insert语句,而且不支持索引。
常应用于日记记录和聚合分析方面。
当然MySql支持的表类型不止上面几种。
总结
今天主要先容了什么是MySql数据库,并进一步引出了它的一个重要特性, 即插入式的多存储引擎机制。然后,简朴先容了什么是存储引擎和MySql中几种主要的存储引擎。
末了,也分享给各人我学习mysql的学习教程,好东西要一起分享!!
MySQL学习教程是动力节点老杜讲的,详细讲解了MySQL的相干知识,包括MySQL概述,MySQL应用环境,MySQL体系特性,MySQL初学基础,MySQL管理工具,如何安装MySQL及MySQL新特性,学mysql,刷完这套视频根本的知识也就掌握了。
需要mysql学习资料的小同伴:关注+私信扣“1”。 |