SQLite和MySQL数据库的区别与应用
简单来说,SQLITE功能简约,小型化,追求最大磁盘效率;MYSQL功能全面,综合化,追求最大并发效率。如果只是单机上用的,数据量不是很大,需要方便移植或者需要频繁读/写磁盘文件的话,就用SQLite比较合适;如果是要满足多用户同时访问,或者是网站访问量比较大是使用MYSQL比较合适。
下面详细介绍两者的区别和应用:
SQLite
SQLite是非凡的数据库,他可以进程在使用它的应用中。作为一个自包含、基于文件的数据库,SQLite提供了出色的工具集,可以处理所有类型的数据,没有什么限制,而且比起服务器运行的进程型服务器使用起来轻松许多。
一个应用使用SQLite时,它的功能直接被集成在其中,应用会直接访问包含数据的文件(即SQLite数据库),而不是通过一些端口(port, socket)来交互。感谢这种底层技术,这使SQLite变得非常快速和高效,并且十分强大。
SQLite支持的数据类型
NULL:
NULL值。
INTEGER:
有符号整数,按照设置用1、2、3、4、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会缺乏一定的特性,如全文搜索。
SQLite和MySQL数据库的区别与应用相关推荐
- plsql和mysql的区别6_Oracle数据库和MySQL数据库的区别(原创)
1.Oracle数据库产品是闭源同时也是收费的,MySQL是开源的项目(免费): 2.Oracle是大型数据库,Mysql是中小型数据库: 3.Oracle可以设置用户权限.访问权限.读写权限等,My ...
- h2 mysql 差别_h2内存数据库和mysql数据库的区别
h2不支持以下配置:ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT '用户表'; h2内存数据库: DROP table if exists 'q_user'; ...
- mysql数据库blob区别_MySQL中TEXT与BLOB字段类型的区别
在MySQL中有两个字段类型容易让人感觉混淆,那就是TEXT与BLOB,特别是自己写博客程序的博主不知道改为自己的博客正文字段选择TEXT还是BLOB类型. 下面给出几点区别: 一.主要差别 TEXT ...
- mysql数据库与oracle_oracle与mysql数据库的区别
区别如下: 一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源的获取.共享与锁定. mysql:mysql以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长, ...
- gp数据库和mysql数据库的区别_pg和gp数据库
查看greemplum资源队列状态SELECT * FROM gp_toolkit.gp_resqueue_status; 查看greemplum资源队列锁SELECT * FROM gp_toolk ...
- 「高并发秒杀」mysql数据库引擎区别
一.秒杀系统架构设计都有哪些关键点? 二.设计秒杀系统时应该注意的5个架构原则 架构原则:"4要1不要" 1.1.数据要尽里少 1.2. 请求数要尽里少 1.3.路径要尽里短 1. ...
- mongo数据库和mysql数据库的区别_Mongodb与mysql数据库的区别
MySQLMongoDB说明 mysqldmongod服务器守护进程 mysqlmongo客户端工具 mysqldumpmongodump逻辑备份工具 mysqlmongorestore逻辑恢复工具 ...
- sqlite mysql_两款主流数据库对比,SQLite和MySQL哪款是你的菜?
数据库是按照数据结构来组织.存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管理数据,而转变成用户所需要的各种数据管理的方式 ...
- Mysql数据库与数据库三大范式
作者:左新宇 链接:https://zhuanlan.zhihu.com/p/59394493 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. MySQL 常用命令 ...
最新文章
- ERROR: JVMPI, an experimental interface, is no longer supported.
- 隧道凿岩机器人传感器_【谷企动态】天创电子管廊综合监控平台及机器人系统在国家电网项目顺利交付应用...
- (译)如何使用box2d来做碰撞检测(且仅用来做碰撞检测)
- python003 一 Python起步、pyhthon运行方式、语法结构、python变量
- 关于myeclipse打开jsp巨慢解决方案
- uint16 累加_如何把一个uint16整数分解成两个字节并传输?
- 对比学习在NLP和多模态领域的应用
- cn.cw.gps.domain.VisitReport.setVisitID([Ljava.lang.String;)]
- 最新MyEclipseIDEAWebStorm安装 激活
- DataTable 转换 DataSet
- win7便签怎么一直在桌面显示
- python股票交易模型_利用python建立股票量化交易系统(一)——小市值选股票模型...
- 良心安利动物 恐龙unity3d模型素材网站
- linux运行360wifi,在Linux下使用“360随身WiFi 2”
- 阿里云DevOps助理工程师认证(ACA)笔记
- RTMP、RTSP、m3u8、flv 区别及含义
- PCL实现点云选取并计算选取点法向量及可视化
- Android自定义view之网易云推荐歌单界面
- Niagara N4 与物联网的学习经验分享(一 New Station)
- 中国15家外卖O2O大盘点-2014
热门文章
- Ionic Angular自动捕获错误 配置Angular2.x +
- ORACLE数据库 常用命令和Sql常用语句
- CodeVS 1044 拦截导弹(DP)
- 【leetcode】104. Maximum Depth of Binary Tree
- centos 7.0上RabbitMQ 3.5.6版本多实例启动操作讲解
- Bossie Awards 2015: The best open source applicati
- 修复./mysql/proc
- asp.net 浏览服务器文件
- ancestral 箭头符号,译林版《牛津高中英语》模块五 高二上学期
- php传中文给Java_完美解决PHP中文乱码(转) - - JavaEye技术网站