目前项目中有个应用场景“保存一组数据,如果其中某条数据存在,就更新该条数据,如果不存在这条数据就保存这 条数据”。目前我想到的有两种方法:
第一种方法是查表,看该条数据是否存在,存在就是 update,不存在就 insert。
第二种方法是直接 replace into tablename value (····);
然后百度了下,发现 replace 不存在被替代的数据就当做 insert 用,如果数据存在,先去 delete 然后再去 insert。那么问题来了,哪种效率更高呢?请各位大佬指导下,当然有更好的方案欢迎提出来。
1
FFLY 2017-11-29 15:17:44 +08:00 1
replace
|
2
sun1991 2017-11-29 15:23:29 +08:00
两种方式跑一下测试看看呗.
另外, SQLite 的 transaction 默认是独占更新, 很吃硬盘, 建议上 SSD. |
4
13036101641 2017-11-29 15:39:30 +08:00
我没试过,但是我一直都是按照第一种去做的
|
5
Azra OP @sun1991 恩,但是我项目需要存储的数据不大,估计两者都是差不多。考虑到其他资源,感觉还是用 replace 好,毕竟只用一条语句就能搞定。
|
6
Azra OP @13036101641 我脑海里想到的也是第一种做法,毕竟对数据库了解的不深入,然后找些资料就发现了第二种方法。
|
7
lxiange 2017-11-29 16:29:04 +08:00 1
如果有可以一步完成的操作,通常是一条指令完成更好。
譬如 Java 的 putIfAbsent,不但效率更高(如果先判断再插入,需要遍历两次树结构),也避免了可能存在的同步问题。 |