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

2022-09-30 13:00:07 +08:00
 MrLonely

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

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

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

3809 次点击
所在节点    SQLite
32 条回复
perfectlife
2022-09-30 13:11:21 +08:00
从设计时候应该就开始,尤其是预测会增长到几百 GB,用个 mysql 也不费啥劲
arch9999
2022-09-30 13:15:08 +08:00
迁移起来也简单,但是不加工资就先别搞了。
mejee
2022-09-30 13:18:18 +08:00
肯定是 MySQL ,有相对专业成熟的维护、备份等。sqlLite 是方便,不需要解决配置,端口,用户名,等等复杂问题,但是硬盘坏了呢?服务挂了呢
iseki
2022-09-30 13:19:43 +08:00
换也不妨去换 SQL Server 或者 PostgreSQL ,MySQL 就没必要了吧
iseki
2022-09-30 13:20:08 +08:00
暴论
dcsuibian
2022-09-30 13:21:29 +08:00
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
2022-09-30 13:23:59 +08:00
@perfectlife 主要是这团队里就我一个人会代码,别的地方要花的时间也不少。想先各个方面都搞到能跑起来。但又想心里有数什么时候就改换数据库了。


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


@iseki 这是为啥呀?可以展开讲讲吗?
mxT52CRuqR6o5
2022-09-30 13:27:25 +08:00
我觉得直接折腾 excel 的函数就行了
ipwx
2022-09-30 13:33:01 +08:00
我觉得金融数据一股脑扔给 MySQL 也不行,时序数据的支持,关系数据库都比较那啥。

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

退一步你也可以使用 MySQL 中央数据库 + SQLite 本地缓存的模式。
chendl111
2022-09-30 13:35:24 +08:00
一开始就应该换,做好分库分表,主备同步,在出事的时候才好处理
Rocketer
2022-09-30 13:37:25 +08:00
难道不应该用接口 /实现类来做到随便换数据库吗?将来也许会发展到 mysql 也撑不住,那时换 oracle 就是最快能上线的选择。
janus77
2022-09-30 13:39:59 +08:00
高级特性,比如数据的版本控制、备份、事务、回滚、多个服务同时读写时的一致性、吞吐量较大等情况下的性能、需要支持较复杂的表结构和查询语句
安全,你现在不需要用户名密码不代表以后不要。用户名密码也是安全配置的一部分。还有 MySQL 针对漏洞的安全补丁,MySQL 支持的加密特性等
Mithril
2022-09-30 13:40:27 +08:00
不需要,SQLite 的性能其实很好。
之前测过单表两千万的库也就才 40G 的文件,性能一样可以接受。

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

想要判断什么时候放弃,那就要想清楚你的程序的生命周期。在这个生命周期内,你打算支持多大量的数据,什么样的业务模式。
如果你的程序单机跑没法满足需求,那么可能数据库也要考虑替换。
如果你的程序单机足够满足需求了,没那么大负载也没有高可用需求,那么 SQLite 就是最好的选择。
line
2022-09-30 13:41:51 +08:00
多台服务器,共用一个数据库, 这个 sqlite 就不行吧。
chendl111
2022-09-30 13:42:03 +08:00
@ipwx 金融数据有什么更好的存储方案?
chendl111
2022-09-30 13:44:13 +08:00
@line 好像一般小券商的都只有一台服务器
liuzhaowei55
2022-09-30 13:44:52 +08:00
看场景并不需要换 MySQL ,就自己使用,也没有大并发的需求,至于数据量的增长做好数据分库,一类数据搞一个文件就行了,啥维护成本都没有
Mithril
2022-09-30 13:49:52 +08:00
另外,所谓安全性更不需要考虑。

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

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

更别说 SQLite 你可以加密数据文件,但其实意义不大。能接触到数据库文件,说明也能接触到你的程序文件,更别说你这还是服务器,挂个 debugger 连内存都能 dump 出来。这种情况下讨论安全配置没什么意义。
Mithril
2022-09-30 13:50:39 +08:00
@Mithril typo -> 攻破
fournoas
2022-09-30 13:55:52 +08:00
你这个情景暂时不需要 mysql ,做好数据文件备份就行了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/884005

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX