MySQL是MySQL AB公司自主研发的,是目前最流行的开源关系型数据库管理系统,它支持多线程高并发多用户。
MySQL数据库有简单、高效、可靠的特点。
索引顺序存取数据的方法是ISAM(Indexed Sequential Access Method)存储引擎核心算法的前身。
MySQL最擅长的是查询性能,而不是事务处理了(须要借助第三方存储引擎)。
标准化查询语言的支持,高效的数据存取,不必关注事务完整性,简单易用,而且成本低廉。
MySQL最初抓住了互联网客户,造就了今天MySQL在互联网行业的巨大成功。
功能比较
MySQL基本实现了ANSI SQL 92的大部分标准,仅有少部分并不经常被使用的没有实现。
MySQL存储引擎并没有提供事务支持,但是通过第三方插件式存储引擎InnoDB实现了SQL 92标准定义的4个事务隔离级别的全部。
Oracle数据库就仅仅实现了其中的两种(Serializable和Read Commited),而PostgreSQL支持4种隔离级别。
在可编程支持方面,MySQL和其他数据库相比还有一定的差距(Procedure、Function、Trigger),所支持的功能还比较有限,和其他几大商用数据库管理系统相比,还存在较大的不足。
Oracle有强大的PL/SQL,SQL Server有T-SQL,PostgreSQL也有功能很完善的PL/PGSQL的支持。
整体来说,在功能方面MySQL数据库作为一个通用的数据库管理系统暂时还无法和PostgreSQL相比,但是其功能完全可以满足通用商业需求。
易用性比较
MySQL的优势所在。
MySQL一直都奉行简单易用的原则。
MySQL安装包大小仅100MB左右。
性能比较
仅有Oracle数据库能够与其一较高下。
MySQL一直以来奉行一个原则,那就是在保证足够稳定性的前提下,尽可能地提高自身的处理能力。
在性能和功能方面,MySQL第一考虑的要素主要还是性能。
可靠性
MySQL数据库一直追求简单、高效、可靠。
MySQL的主要适用场景 Web网站系统
Web站点是MySQL最大的客户群,也是MySQL发展史上最为重要的支撑力量。
MySQL的主要适用场景 日志记录系统
MySQL数据库的插入和查询都非常高效,如果设计得较好,在使用MyISAM存储引擎的时候,两者可以做到互不锁定,具有很高的并发性能。
对需要大量插入和查询日志记录的系统,比如处理用户的登录日志、操作日志等,都是非常适合的应用系统。
MySQL的主要适用场景 数据仓库系统
一种是采用昂贵的高性能主机以提高计算性能,用高端存储设备提高I/O性能,这样做效果理想,但成本非常高;
第二种就是将数据复制到多台使用大容量硬盘的廉价PC Server上,以提高整体计算性能和I/O能力,这样实施效果尚可,存储空间虽有一定限制,但成本低廉;
第三种,通过将数据水平拆分,使用多台廉价的PC Server和本地磁盘来存放数据,每台机器上面都只有所有数据的一部分,这样便解决了数据量的问题,所有PC Server一起并行计算,也解决了计算能力问题,通过中间代理程序调配各台机器的运算任务,既可以解决计算性能问题又可以解决I/O性能问题,成本也很低廉。
第二种和第三种方案,MySQL都有较大的优势。
第一种方案所有数据库系统都能够实现,但是成本高昂。
比较成熟的数据仓库解决方案主要是MySQL与Infobright相结合的DW系统。
MySQL的主要适用场景 嵌入式系统
嵌入式环境硬件资源非常有限,在嵌入式环境下运行的软件系统,必须是轻量级低消耗的软件。
MySQL在资源的使用方面伸缩性非常大。MySQL有专门针对嵌入式环境的版本。