V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
yccyeng
V2EX  ›  程序员

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

  •  
  •   yccyeng · 2023-02-21 17:41:42 +08:00 · 971 次点击
    这是一个创建于 424 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    thunderw
        1
    thunderw  
       2023-02-21 17:50:06 +08:00
    建个表,把这些字符串存进去。然后和这个表 join 一下。
    aleiweb
        2
    aleiweb  
       2023-02-21 17:53:48 +08:00
    转换成子查询或者 join
    ufo5260987423
        3
    ufo5260987423  
       2023-02-21 18:07:06 +08:00
    布隆过滤器……
    Red998
        4
    Red998  
       2023-02-21 18:07:36 +08:00
    sheet_series_no 加个合理的前缀索引 。按照你这样的需求 可以考虑 在代码方面解决 一次查询少量数据。在索引下问题不大。
    mingl0280
        5
    mingl0280  
       2023-02-22 04:04:16 +08:00 via Android
    先全 select 出来再在内存里匹配呗,内存当缓存了。
    yccyeng
        6
    yccyeng  
    OP
       2023-02-22 09:23:41 +08:00
    @aleiweb 感谢老哥 我试一下
    yccyeng
        7
    yccyeng  
    OP
       2023-02-22 09:24:29 +08:00
    @thunderw 感谢老哥,先存再 join 我试一下
    yccyeng
        8
    yccyeng  
    OP
       2023-02-22 09:24:51 +08:00
    @ufo5260987423 感谢老哥 我去研究下
    yccyeng
        9
    yccyeng  
    OP
       2023-02-22 09:26:43 +08:00
    @redorblacck886 我试一下 感谢老哥
    yccyeng
        10
    yccyeng  
    OP
       2023-02-22 09:32:02 +08:00
    @mingl0280 也可以 占用不了多少内存,我试一下
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2634 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 10:22 · PVG 18:22 · LAX 03:22 · JFK 06:22
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.