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会缺乏一定的特性,如全文搜索。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/463720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第九章 虚拟内存

物理地址和虚拟地址: 计算机的主存被组织成一个由M个连续的字节大小的单元组成的数组。每个字节都有一个唯一的物理地址(PA)。第一个字节地址为0,接下来为1,再接下来为2,依次类推。CPU访问内存的最自然方式…

Safari browser and asp.net Menu control (asp:Menu)

问题: asp:Menu 在Safari浏览器中显示不正常。 解决方法一:(App_Browsers) Step1: Add App_Browser Folder in application right click on project add ASP.Net Folder - App_Browsers right click on App_Browsers -- Add new…

CentOS常用到的查看系统命令

# uname -a # 查看内核/操作系统/CPU信息 # head -n 1 /etc/issue # 查看操作系统版本 # cat /proc/cpuinfo # 查看CPU信息 # hostname # 查看计算机名 # lspci -tv # 列出所有PCI设备 # lsusb -tv # 列出所有USB设备 # lsmod…

Android HandlerThread 总结使用

Android HandlerThread 总结使用转载请标明出处:http://www.cnblogs.com/zhaoyanjun/p/6062880.html本文出自【赵彦军的博客】前言以前我在 【Android Handler、Loop 的简单使用】 介绍了子线程和子线程之间的通信。很明显的一点就是,我们要在子线程中调…

[MathType需要安装新版的MT EXtra字体]解决方法

MathType是一款强大的数学公式编辑器,当安装完成(或者使用绿色版)打开程序时,常常弹出缺少字体的对话框,如下: MathType需要一个新版的MT Extra(TrueType)字体。请重新安装MathType&…

Microsoft Lync

转载于:https://blog.51cto.com/dynamicit/874659

python 文件操作练习

1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数。 apple 10 3 tesla 100000 1 mac 3000 2 lenovo 30000 3 chicken 10 3 通过代码,将其构建成这种数据类型:[{name:apple,price:10,amount:3},{name:tesla,price:…

超级简单的数学题

超级简单的数学题有5人坐在一起,当问第5个人多少岁,他说比第4个人大2岁,问第4个人多少岁,他说比第3个人大2岁,依此下去,问第一个人多少岁,他说他10岁,最后求第5个人多少岁如果所坐的不是5人而是n人&#xf…

Linux下共享内存的查看和释放

说明:1、查看共享内存,使用命令:ipcs -m2、删除共享内存,使用命令:ipcrm -m [shmid]使用如下:[plain] view plaincopy[negivupnegivup mycode]$ ipcs -m 查看共享内存区 ------…

微软发布Enterprise Library 4.1和Unity 1.2

说明 微软模式与实践团队今天发布了Enterprise Library 4.1和Unity 1.2版本,这次发布的主要新特性如下: 1. 支持Visual Studio 2008 SP1 2. Unity应用程序块中加入了拦截机制 3. 性能提升 4. 配置工具的可用性提升 5. Bugs修复。 在Unity 1.2中有如下几点…

简易的波形折叠电路

01 波形折叠一、背景介绍今天在 Youtube 上看到 UP 主 Neukolln 展示了一款非常简单波形折叠电路。那么什么是波形折叠电路?它有什么用处?1、什么是波形折叠?通常情况下,信号在放大中会产生“饱和失真”,这是由于放大器…

STL 容器和迭代器连载6_顺序容器的操作3

2019独角兽企业重金招聘Python工程师标准>>> /*- * 文件名 :STL_con_ite_6.cpp * 开发人员:袁培荣 * 当前版本:1.0.0.2595 * 创建时间:2012-05-24 * 修改时间:2012-05-24 * 功能…

hive三种调用方式

一、hive -e ‘sql语句’ (shell命令) 适合比较短的sql语句调用,优点是可以直接在shell中调用静音模式 -S 在执行HiveQL过程中,不在显示器输出MR的执行过程hive -S -e ‘sql语句’ > test.txt 将执行结果直接输入到本地文件 二…

vector的内存释放

1. vector容器的内存自增长 与其他容器不同,其内存空间只会增长,不会减小。先来看看"C Primer"中怎么说:为了支持快速的随机访问,vector容器的元素以连续方式存放,每一个元素都紧挨着前一个元素存储。设想一…

从程序语言排行榜来解读IT及Web的发展

预测行业的发展不能是凭空预测,而需要有根据。因为预测本身就是个不太准的事情,再没根据的话,那就更是浮云了。下面,我尝试从程序语言排行榜来解读一下IT的发展方向及Web的未来。《2012年4月份编程语言排行榜》全文见 http://news…

QT - 内存泄漏检测

一、安装vld-2.5.1-setup.exe 下载地址:https://archive.codeplex.com/?pvld 二、pro中添加头文件目录与库目录 INCLUDEPATH "C:\\Program Files (x86)\\Visual Leak Detector\\include"LIBS "C:\\Program Files (x86)\\Visual Leak Detector\\li…

C和C++混合编程(__cplusplus 与 external c 的使用)

第一种理解比如说你用C开发了一个DLL库,为了能够让C语言也能够调用你的DLL输出(Export)的函数,你需要用extern "C"来强制编译器不要修改你的 函数名。 通常,在C语言的头文件中经常可以看到类似下面这种形式的代码: #ifd…

Eclipse开发Android程序如何在手机上运行

http://www.cnblogs.com/plwang1990/archive/2011/07/04/2097757.htm android开发不论是在真机上调试还是最终发布到真机上都非常简单,过程如下: 1、安装usb驱动 手机要能与电脑相连,当然要安驱动了。效果就是你插入手机,电脑显示…

Python 字符串 String 内建函数大全(1)

关于 Python 的字符串处理相关的方法还是非常多的,由于我正在学习 Python,于是就把 Python 中这些混杂的用于 string 的函数总结出来,在自己忘记的时候便于查找,希望对于有类似需求的人有所帮助。 captalize() 函数 功能 将一个字…

表单PostGet两个长度限制问题的分析

一、问题起因在某项目释放后Bug统计的附件《释放后问题》里有: 问题 原因 分析 备注 CSV处理时,如果处理的主题数过多,发生URL参数上限的错误; 可变长度的参数通过URL方式传递,会造成这种潜在的错误发生。 1、属于2次…