V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
iffi
V2EX  ›  问与答

MySQL join 问题

  •  
  •   iffi · 2017-08-07 20:03:07 +08:00 · 1564 次点击
    这是一个创建于 2697 天前的主题,其中的信息可能已经有所发展或是发生改变。

    有一个业务场景,MySQL 查询数据 join 连接太多,现在打算新建单一数据表存放 join 关联后的数据。
    出现的问题:若待 join 表中的某一个表中的字段做了修改,如何把结果及时同步到单一库中去

    10 条回复    2017-08-08 13:46:47 +08:00
    Jakesoft
        1
    Jakesoft  
       2017-08-07 20:09:17 +08:00 via iPhone
    触发器?
    iffi
        2
    iffi  
    OP
       2017-08-07 20:19:37 +08:00
    待 join 的表修改的操作由 php 来完成。 这个新建的单一数据表 主要由 Java 操作用于提供外界查询(里面的数据需要热数据,即 join 表的某一个表有变化,需要及时体现在这个用于聚合数据的单一表中去)
    akira
        3
    akira  
       2017-08-07 21:21:08 +08:00   ❤️ 1
    @iffi 既然修改操作是代码完成的,那你可以在操作的代码后面加一句去做 join 表更新操作啊。或者如果要求不是那么实时的话,也可以做个定时器去刷新就是了。

    另外,不建议用数据库的触发器。
    sudoz
        4
    sudoz  
       2017-08-07 21:25:58 +08:00   ❤️ 1
    不建议使用 join
    重新涉及库表
    iffi
        5
    iffi  
    OP
       2017-08-07 22:10:11 +08:00
    目前想到两个方案:
    * 把 join 后的数据存放到 redis
    * 定时扫描修改记录(有数据 update_date 字段)
    Infernalzero
        6
    Infernalzero  
       2017-08-07 22:43:48 +08:00
    你这样还不如直接用 solr 或者 ES
    实时性要求高一些的话就直接加冗余字段吧,再不济可以上 canal
    syncher
        7
    syncher  
       2017-08-07 22:50:05 +08:00 via Android
    @akira 为啥不建议触发器?
    iffi
        8
    iffi  
    OP
       2017-08-08 09:46:37 +08:00
    @Infernalzero 没用过 solr 和 ES,我去了解下。另外,我发现用 redis 涉及到数据分页,第一种方案应该不可取
    Infernalzero
        9
    Infernalzero  
       2017-08-08 13:42:40 +08:00
    redis 也可以做分页的
    iffi
        10
    iffi  
    OP
       2017-08-08 13:46:47 +08:00
    @Infernalzero 看到了 lrange 但是还是觉得数据太大了。会把 redis 搞挂了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1079 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 150ms · UTC 19:12 · PVG 03:12 · LAX 11:12 · JFK 14:12
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.