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

《求助》关于搜索条件的技术实现。

  •  
  •   masterDu · 2020-07-24 15:36:53 +08:00 · 1637 次点击
    这是一个创建于 1582 天前的主题,其中的信息可能已经有所发展或是发生改变。
    1. 一个 1900 万数据的表
    2. 以 code (职位,例如:初级开发工程师)为主,搜索条件填写 code 后,找到 code 对应的全部有效的搜索条件
    3. 地区 140 条,行业 168 条,规模或性质 11 条,理论情况组合起来有 258720 种组合

    举例:搜索框中填写 "AB123" 对应搜索条件"地区"中无数据的条件显示灰色,选择地区后 对应"行业"与"规模或性质"中无数据的条件显示灰色,选择行业后 对应"规模"中无数据的条件显示灰色 地区,行业,规模或性质无优先级;可以先选择行业或规模或性质,则对应地区,规模或性质(或行业)中无数据的条件显示灰色

    问题:1. 解决这个搜索条件的思路,包括但不限于数据库分表,前端页面插件,搜索算法优化等 2. 如果需要解决这个问题需要去 google 、baidu 搜索什么关键字等

    10 条回复    2020-07-28 15:06:20 +08:00
    gantleman
        1
    gantleman  
       2020-07-24 15:40:37 +08:00   ❤️ 1
    搜索框架 Lucene
    masterDu
        2
    masterDu  
    OP
       2020-07-24 15:46:01 +08:00
    @gantleman 谢谢
    masterDu
        3
    masterDu  
    OP
       2020-07-24 16:05:04 +08:00
    刚才查了一下 Lucene 这个框架,与我的需求不符!我是想对搜索条件做一些 无数据就不能选的处理 ,哪位有想法麻烦再提点一下 谢谢
    一些简单的思路也可以,如果我的需求描述的还不够明确可以 @我,我再做详细解答
    zarte
        4
    zarte  
       2020-07-24 16:23:20 +08:00   ❤️ 1
    简单思路就是分别 groupby 行业 xx 字段然后 0 或不存在就不能选。。
    zzl22100048
        5
    zzl22100048  
       2020-07-24 19:26:40 +08:00 via iPhone   ❤️ 1
    elaticsearch 聚合
    keepeye
        6
    keepeye  
       2020-07-24 19:43:58 +08:00   ❤️ 1
    后台定时把所有条件跑一遍,有没有结果缓存起来,前台直接从缓存取。
    aguesuka
        7
    aguesuka  
       2020-07-24 20:34:13 +08:00   ❤️ 1
    后台存一个三维数组[地区][行业][规模] = 人数。加人和删除人的复杂度是 O(1)。定时把这个三维数组转成 bitArray,大约 31.5kb 。前段根据查询出这个 bitArray 来作判断
    lidlesseye11
        8
    lidlesseye11  
       2020-07-24 20:34:30 +08:00   ❤️ 1
    1. code 有多少种呢?
    2. 你目前尝试了啥方法?遇到了具体啥问题?(比如用 group by 去做,结果要花好几十秒)
    masterDu
        9
    masterDu  
    OP
       2020-07-28 15:05:00 +08:00
    @lidlesseye11 谢谢回答,code 大概有 4000 个;这个功能暂时搁置了,因为还没有思路目前还没尝试任何方法。
    masterDu
        10
    masterDu  
    OP
       2020-07-28 15:06:20 +08:00
    @aguesuka 谢谢 这应该是一种思路,我还没开始做,我开始的做的时候会尝试一下这个方法
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   930 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 22:19 · PVG 06:19 · LAX 14:19 · JFK 17:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.