对于不适合加索引的场景,如何做到数据判重?

2022-02-27 23:35:51 +08:00
 leebs

一种是直接查询数据库,但是因为字段没有索引,查询会非常慢。 另一种是双写到缓存中,通过 set 存放和校验重复数据,但这样全量刷新缓存时,会有缓存和数据库数据不一致的可能,有什么好的办法嘛?

2063 次点击
所在节点    程序员
10 条回复
yhvictor
2022-02-27 23:45:19 +08:00
没懂全量刷新为啥不一致,望解释。
单独起个服务器维护个索引不就好了?
rekulas
2022-02-27 23:49:46 +08:00
@yhvictor 他是说缓存和数据库一致性问题,这个没有真正完美解决方案,日经贴

缓存是个方案,担心全量刷新出问题具体是如何操作的?是否可以刷新时加锁保证一致性,还有字段为什么不能加索引,查询并发数大概什么级别,不同情况有不同解决方案
timethinker
2022-02-28 00:23:46 +08:00
不能加索引是因为数据量太大的原因?有没有实际测试过写入的时候性能影响?不要猜测,要动手测试。
mineralsalt
2022-02-28 00:36:01 +08:00
要么查数据库, 要么查缓存, 要么就设计一种保证不会重复的数据生成方案, 例如 UUID
nebkad
2022-02-28 04:01:35 +08:00
Hash and/or Merkel Tree
totoro52
2022-02-28 10:05:35 +08:00
我没理解楼主的意思,但不想通过加索引来解决唯一性,可以试试外加一个字段,这个字段是重要值加起来算出来的 md5 ,每次入值时查询一遍这个 md5 ,l 就能达到唯一了
opengps
2022-02-28 10:15:55 +08:00
哈希值进缓存,写入时候检查比对
bthulu
2022-02-28 11:05:35 +08:00
缓存不能当数据库用的, 缓存只是缓存, 只用于提高查询性能, 当数据库用, 哪天缓存崩一下搞不死你
yibo2018
2022-02-28 13:35:33 +08:00
前几天总结了下这个问题,最终处理方案是把需要唯一的字段拼接起来,创建一个中间表,把这个新的字段当唯一索引
jones2000
2022-02-28 16:25:26 +08:00
要一致就锁表, 等两边都更新完了,在解锁

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

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

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

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

© 2021 V2EX