4

在什么情况下一定要放弃 SQLite 采用 MySQL 呢?

 1 year ago
source link: https://www.v2ex.com/t/884005
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

V2EX  ›  SQLite

在什么情况下一定要放弃 SQLite 采用 MySQL 呢?

  MrLonely · 8 小时 35 分钟前 · 1750 次点击

现在在一家小公司里帮忙做一些数据处理,金融方面的。数据都是从人工处理过的 Excel 里来的。目前数据放进 SQLite 里大概数据库文件大小在 500MB 左右。后续可能会增长到几百 GB 。

因为 SQLite 简单,不需要解决配置,端口,用户名,等等复杂问题。即开即用。

那以后到了什么时候就该从 SQLite 换到 MySQL 了呢?或者换到 SQL Server ?

27 条回复    2022-09-30 15:55:11 +08:00
perfectlife

perfectlife      8 小时 24 分钟前

从设计时候应该就开始,尤其是预测会增长到几百 GB,用个 mysql 也不费啥劲
arch9999

arch9999      8 小时 20 分钟前

迁移起来也简单,但是不加工资就先别搞了。
mejee

mejee      8 小时 17 分钟前

肯定是 MySQL ,有相对专业成熟的维护、备份等。sqlLite 是方便,不需要解决配置,端口,用户名,等等复杂问题,但是硬盘坏了呢?服务挂了呢
iseki

iseki      8 小时 16 分钟前 via Android

换也不妨去换 SQL Server 或者 PostgreSQL ,MySQL 就没必要了吧
iseki

iseki      8 小时 15 分钟前 via Android

dcsuibian

dcsuibian      8 小时 14 分钟前   ❤️ 1

SQLite 的读写效率很高,有哪些使用其他数据库的理由? - zzl0 的回答 - 知乎
https://www.zhihu.com/question/31417262/answer/881191147

SQLite 文档指出了什么时候用 client/server SQL 数据库(如 MySQL )
1 、Is the data separated from the application by a network? → choose client/server
2 、Many concurrent writers? → choose client/server
3 、Big data? → choose client/server
4 、Otherwise → choose SQLite!
MrLonely

MrLonely      8 小时 11 分钟前

@perfectlife 主要是这团队里就我一个人会代码,别的地方要花的时间也不少。想先各个方面都搞到能跑起来。但又想心里有数什么时候就改换数据库了。


@mejee SQLite 就一个文件,暂时用 NAS 备份。MySQL 那些专业的方案我现在都没了解过啊。有什么博客或者链接推荐一下,我去了解了解吗?


@iseki 这是为啥呀?可以展开讲讲吗?
mxT52CRuqR6o5

mxT52CRuqR6o5      8 小时 8 分钟前 via Android

我觉得直接折腾 excel 的函数就行了
ipwx

ipwx      8 小时 2 分钟前

我觉得金融数据一股脑扔给 MySQL 也不行,时序数据的支持,关系数据库都比较那啥。

提高速度的关键在于自己分库分表,优化时间序列的索引方式。但说实话如果你能做到这一步,用 SQLite 你也能做。另一方面金融数据库一般很多时候会用来做实验,如果你能用 SQLite 解决这些事情,你天然多了一种在实验机器上本地缓存数据的方案,这样可以大大减轻你 MySQL 中央数据库的压力。

退一步你也可以使用 MySQL 中央数据库 + SQLite 本地缓存的模式。
chendl111

chendl111      8 小时 0 分钟前

一开始就应该换,做好分库分表,主备同步,在出事的时候才好处理
Rocketer

Rocketer      7 小时 58 分钟前 via iPhone

难道不应该用接口 /实现类来做到随便换数据库吗?将来也许会发展到 mysql 也撑不住,那时换 oracle 就是最快能上线的选择。
janus77

janus77      7 小时 55 分钟前

高级特性,比如数据的版本控制、备份、事务、回滚、多个服务同时读写时的一致性、吞吐量较大等情况下的性能、需要支持较复杂的表结构和查询语句
安全,你现在不需要用户名密码不代表以后不要。用户名密码也是安全配置的一部分。还有 MySQL 针对漏洞的安全补丁,MySQL 支持的加密特性等
Mithril

Mithril      7 小时 55 分钟前

不需要,SQLite 的性能其实很好。
之前测过单表两千万的库也就才 40G 的文件,性能一样可以接受。

而且备份极其简单,特别是你客户没有专业运维的时候,告诉他们下班停了程序文件复制一份就行了。

想要判断什么时候放弃,那就要想清楚你的程序的生命周期。在这个生命周期内,你打算支持多大量的数据,什么样的业务模式。
如果你的程序单机跑没法满足需求,那么可能数据库也要考虑替换。
如果你的程序单机足够满足需求了,没那么大负载也没有高可用需求,那么 SQLite 就是最好的选择。
line

line      7 小时 53 分钟前

多台服务器,共用一个数据库, 这个 sqlite 就不行吧。
chendl111

chendl111      7 小时 53 分钟前

@ipwx 金融数据有什么更好的存储方案?
chendl111

chendl111      7 小时 51 分钟前

@line 好像一般小券商的都只有一台服务器
liuzhaowei55

liuzhaowei55      7 小时 50 分钟前 via iPhone

看场景并不需要换 MySQL ,就自己使用,也没有大并发的需求,至于数据量的增长做好数据分库,一类数据搞一个文件就行了,啥维护成本都没有
Mithril

Mithril      7 小时 45 分钟前

另外,所谓安全性更不需要考虑。

当一个人可以物理访问到你的机器时,你就可以认为已经被公婆了。

从这方面考虑,SQLite 的安全性远超所有其它数据库。

更别说 SQLite 你可以加密数据文件,但其实意义不大。能接触到数据库文件,说明也能接触到你的程序文件,更别说你这还是服务器,挂个 debugger 连内存都能 dump 出来。这种情况下讨论安全配置没什么意义。
Mithril

Mithril      7 小时 45 分钟前

@Mithril typo -> 攻破
fournoas

fournoas      7 小时 39 分钟前

你这个情景暂时不需要 mysql ,做好数据文件备份就行了
fds

fds      7 小时 32 分钟前

@Mithril SQLite 可以不停程序直接备份吗?前段时间看 https://litestream.io/ 这种专门的备份软件应该是支持。但不确定直接文件复制会不会出错。
Mithril

Mithril      7 小时 25 分钟前   ❤️ 1

@fds 可以,SQLite 有 Online Backup API ,https://sqlite.org/backup.html
它的命令行工具就可以直接做 backup
nekoneko

nekoneko      6 小时 49 分钟前

高并发下换, 数据量大了换
tigerstudent

tigerstudent      6 小时 39 分钟前

以前一单机项目用 SQLite ,不知道怎么回事,个别机器(多台)会偶发 SQLite 文件损坏
ipwx

ipwx      6 小时 33 分钟前

@chendl111 空口说这个没用的,要看数据使用流程。
mywaiting

mywaiting      5 小时 40 分钟前

只要是单机版,SQLite 能吊打其他数据库,无论性能还是代码实现的容易程度

什么时候放弃用 SQLite ,那就是你放弃单机版的实现的时候

相对客观地说,这个世界大多数的应用都熬不过需要从 SQLite 转换到 MySQL 分库的时候

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK