SQLite与MySQL区别

原文连接:https://blog.csdn.net/zbw1185/article/details/47975965
简单来讲,SQLITE功能简约,小型化,追求最大磁盘效率;MYSQL功能全面,综合化,追求最大并发效率。若是只是单机上用的,数据量不是很大,须要方便移植或者须要频繁读/写磁盘文件的话,就用SQLite比较合适;若是是要知足多用户同时访问,或者是网站访问量比较大是使用MYSQL比较合适。sql


下面详细介绍二者的区别和应用:数据库

SQLite安全

SQLite是非凡的数据库,他能够进程在使用它的应用中。做为一个自包含、基于文件的数据库,SQLite提供了出色的工具集,能够处理全部类型的数据,没有什么限制,并且比起服务器运行的进程型服务器使用起来轻松许多。性能优化

一个应用使用SQLite时,它的功能直接被集成在其中,应用会直接访问包含数据的文件(即SQLite数据库),而不是经过一些端口(port, socket)来交互。感谢这种底层技术,这使SQLite变得很是快速和高效,而且十分强大。服务器

SQLite支持的数据类型并发

NULL:socket

NULL值。分布式

INTEGER:工具

有符号整数,按照设置用一、二、三、四、6或8字节存储。性能

REAL:

浮点数,使用8字节IEEE浮点数方式存储。

TEXT:

文本字符串,使用数据库编码存储(UTF-8, UTF-16BE 或 UTF-16LE)。

BLOB:

二进制大对象,怎么输入就怎么存储。

注: 想了解更多有关SQLite数据类型的信息,能够查看这一主题的 官方文档 。

SQLite 的优势

基于文件:

整个数据库都包含在磁盘上的一个文件中,所以它有很好的迁移性。

标准化:

尽管它看起来像个“简化版”的数据库,SQLite 确实支持 SQL。它略去了一些功能(RIGHT OUTER JOIN 和 FOR EACH STATEMENT),可是,又同时增长了一些其余功能。

对开发乃至测试都很棒:

在绝大多数应用的开发阶段中,大部分人都很是须要解决方案能有并发的灵活性。SQLite 含有丰富功能基础,所能提供的超乎开发所需,而且简洁到只需一个文件和一个 C 连接库。

SQLite的缺点

没有用户管理:

高级数据库都能支持用户系统,例如,能管理数据库链接对数据库和表的访问权限。但因为 SQLite 产生的目的和自己性质(没有多用户并发的高层设计),它没有这个功能。

缺少额外优化性能的灵活性:

仍然是从设计之初,SQLite 就不支持使用各类技巧来进行额外的性能优化。这个库容易配置,容易使用。既然它并不复杂,理论上就没法让它比如今更快,其实如今它已经很快了。

什么时候使用 SQLite ?

嵌入式应用:

全部须要迁移性,不须要扩展的应用,例如,单用户的本地应用,移动应用和游戏。

代替磁盘访问:

在不少状况下,须要频繁直接读/写磁盘文件的应用,都很适合转为使用 SQLite ,能够得益于 SQLite 使用 SQL 带来的功能性和简洁性。

测试:

它能秒杀大部分专门针对应用业务逻辑(也就是应用的主要目的:能完成功能)的测试。

什么时候不用 SQLite ?

多用户应用:

若是你在开发的应用须要被多用户访问,并且这些用户都用同一个数据库,那么相比 SQLite 最好仍是选择一个功能完整的关系型数据库(例如 MySQL)。

须要大面积写入数据的应用:

SQLite 的缺陷之一是它的写入操做。这个数据库同一时间只容许一个写操做,所以吞吐量有限。

MySQL

MySQL 在全部大型数据库服务器中最流行的一个. 它的特性丰富,产品的开源性质使得其驱动了线上大量的网站和应用程序. 要入手 MySQL 相对简单,开发人员能够在互联网上面访问到大量有关这个数据库的信息.

注意: 因为这个产品的普及性,大量的第三方应用、工具和集成库对于操做这个RDBCMS的方方面面大有帮助.

Mysql没有尝试去实现SQL标准的所有,而是为用户提供了不少有用的功能. 做为一个独立的数据库服务器,应用程序同Mysql守护进程的交互,告诉它去访问数据库自身 -- 这一点不像 SQLite.

MySQL支持的数据类型

TINYINT:

一个很是小的整数.

SMALLINT:

一个小整数.

MEDIUMINT:

一个中间大小的整数.

INT or INTEGER:

一个正常大小的整数.

BIGINT:

一个大的整数.

FLOAT:

一个小的 (单精度) 浮点数,不能是无符号的那种.

DOUBLE, DOUBLE PRECISION, REAL:

一个正常大小 (双精度) 的浮点数,不能使无符号的那种.

DECIMAL, NUMERIC:

没有被包装的浮点数。不能使无符号的那种.

DATE:

一个日期.

DATETIME:

一个日期和时间的组合.

TIMESTAMP:

一个时间戳.

TIME:

一个时间.

YEAR:

一个用两位或者4位数字格式表示的年份(默认是4位).

CHAR:

一个固定长度的字符串,存储时老是在其固定长度的空间里右对齐.

VARCHAR:

一个可变长度的字符串.

TINYBLOB, TINYTEXT:

一个BLOB或者TEXT列,最大长度255 (2^8 - 1)个字符.

BLOB, TEXT:

一个BLOB或者TEXT列,最大长度 65535 (2^16 - 1)个字符.

MEDIUMBLOB, MEDIUMTEXT:

一个BLOB或者TEXT列,最大长度 16777215 (2^24 - 1)个字符.

LONGBLOB, LONGTEXT:

一个BLOB或者TEXT列,最大长度4294967295 (2^32 - 1) 个字符.

ENUM:

一个枚举类型.

SET:

一个集合.

MySQL的优势

容易使用:

安装MySQL很是容易。第三方库,包括可视化(也就是有GUI)的库让上手使用数据库很是简单。

功能丰富:

MySQL 支持大部分关系型数据库应该有的 SQL 功能——有些直接支持,有些间接支持。

安全:

MYSQL 有不少安全特性,其中有些至关高级。

灵活而强大:

MySQL 能处理不少数据,此外若有须要,它还能“适应”各类规模的数据。

快速:

放弃支持某些标准,让 MySQL 效率更高并能使用捷径,所以带来速度的提高。

MySQL的缺点

已知的局限:

从设计之初,MySQL 就没打算作到全知全能,所以它有一些功能局限,没法知足某些顶尖水平应用的需求。

可靠性问题:

MySQL 对于某些功能的实现方式(例如,引用,事务,数据审核等) 使得它比其余一些关系型数据库略少了一些可靠性。

开发停滞:

尽管 MySQL 理论上还是开源产品,也有人抱怨它诞生以后更新缓慢。然而,应该注意到有一些基于 MySQL 并完整集成的数据库(如 MariaDB),在标准的 MySQL 基础上带来了额外价值。

什么时候使用 MySQL?

分布式操做:

当SQLite所提供的不能知足你的须要时,能够把MySQL包括进你的部署栈,就像任何一个独立的数据库服务器,它会带来大量的操做自由性和一些先进的功能。

高安全性:

MySQL的安全功能,用一种简单的方式为数据访问(和使用)提供了可靠的保护。

Web网站 和 Web应用:

绝大多数的网站(和Web应用程序)能够忽视约束性地简单工做在MySQL上。这种灵活的和可扩展的工具是易于使用和易于管理的——这被证实很是有助于长期运行。

定制解决方案:

若是你工做在一个高度量身定制的解决方案上,MySQL可以很容易地尾随和执行你的规则,这要感谢其丰富的配置设置和操做模式。

什么时候不用 MySQL?

SQL 服从性:

由于 MySQL 没有[想要]实现 SQL 的所有标准,因此这个工具不彻底符合SQL。若是你须要对这样的关系数据库管理系统进行整合,从MySQL进行切换是不容易的。

并发:

即便MySQL和一些存储引擎可以真地很好执行读取操做,但并发读写仍是有问题的。

缺少特点:

再次说起,根据数据库引擎的选择标准,MySQL会缺少必定的特性,如全文搜索。