老哥们 有 3000 个字符串 怎么找出数据库中某个字段和它匹配的数据呢

2023-02-21 17:41:42 +08:00
 yccyeng

数据库中大概有 300w 条数据,现在是直接用 sql 的 in 语句查的 非常慢 大概要 10s select * from table_name where sheet_series_no in ('','','','');有没有其它好的办法呢

980 次点击
所在节点    程序员
10 条回复
thunderw
2023-02-21 17:50:06 +08:00
建个表,把这些字符串存进去。然后和这个表 join 一下。
aleiweb
2023-02-21 17:53:48 +08:00
转换成子查询或者 join
ufo5260987423
2023-02-21 18:07:06 +08:00
布隆过滤器……
Red998
2023-02-21 18:07:36 +08:00
sheet_series_no 加个合理的前缀索引 。按照你这样的需求 可以考虑 在代码方面解决 一次查询少量数据。在索引下问题不大。
mingl0280
2023-02-22 04:04:16 +08:00
先全 select 出来再在内存里匹配呗,内存当缓存了。
yccyeng
2023-02-22 09:23:41 +08:00
@aleiweb 感谢老哥 我试一下
yccyeng
2023-02-22 09:24:29 +08:00
@thunderw 感谢老哥,先存再 join 我试一下
yccyeng
2023-02-22 09:24:51 +08:00
@ufo5260987423 感谢老哥 我去研究下
yccyeng
2023-02-22 09:26:43 +08:00
@redorblacck886 我试一下 感谢老哥
yccyeng
2023-02-22 09:32:02 +08:00
@mingl0280 也可以 占用不了多少内存,我试一下

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

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

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

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

© 2021 V2EX