MySQL支持的数据类型
MySQL支持的数据类型包括TINYINT、SMALLINT、MEDIUMINT、INT或INTEGER、BIGINT、FLOAT、DOUBLE、DOUBLE PRECISION、REAL、DECIMAL、NUMERIC、DATE、DATETIME、TIMESTAMP、TIME、YEAR、CHAR、VARCHAR、TINYBLOB, TINYTEXT、BLOB, TEXT、MEDIUMBLOB、MEDIUMTEXT、LONGBLOB, LONGTEXT、ENUM、SET。
MySQL的优点
- 易用
很容易安装。第三方工具,包括可视化工具,让用户能够很容易入门。
- 功能丰富
MySQL支持关系型数据库应该有的大部分功能——或者直接支持、或者间接支持。
- 安全
支持很多安全特性,有些非常高级,并且是内置于MySQL中。
- 可扩展也非常强大
MySQL能够处理大量数据,并且在需要的时候可以规模化使用。
- 快速
放弃某些标准让MySQL能够非常高效、简捷地工作,因而速度更快。
MySQL的缺点
- 已知限制
MySQL从一开始就没有打算做所有事情,因而它在功能方面有一定的局限性,并不能满足一些先进应用程序的要求。
- 可靠性问题
MySQL对某些功能(例如引用、事务、审计等)的实现方式使得它与其他的关系型数据库相比缺少了一些可靠性。
- 开发停滞
尽管MySQL依然是一款开源产品,但是自从它被收购之后人们就对其开发进展有很多抱怨。需要注意的是有一些基于MySQL的、完整集成的数据库在标准的MySQL之上附加了其他价值,例如MariaDB。
何时应该使用MySQL
- 分布式操作
如果SQLite不能满足你的需求,那么将MySQL引入到开发栈中,就像任何其他独立的数据库服务器一样,它能够给你带来大量的操作自由度以及一些先进的功能。
- 高安全性
MySQL的安全机制通过一种简单的方式为数据的访问和使用提供了可靠的保护。
- 网站和Web应用
尽管有一些约束,但是绝大部分网站和Web应用都可以简单地运行在MySQL上。相关的灵活可扩展的工具非常易于使用和管理——事实证明这些工具在长期运行时非常有用。
- 定制解决方案
MySQL有丰富的配置项和运行模式,如果你需要一个高度量身定制的解决方案,那么MySQL能够非常容易地尾随并执行你的规则。
何时不应该使用MySQL
- SQL遵从性
因为MySQL并没有打算实现完整的SQL标准,所以它并不完全符合SQL。如果你可能需要与这样的关系型数据库集成,那么从MySQL切换过去可能并不容易。
- 并发性
尽管MySQL和一些其他的存储引擎能够非常好地执行读操作,但是并发读写可能会有问题。
- 缺少功能
MySQL缺少某些功能,例如全文本搜索。