有一个业务场景,MySQL 查询数据 join 连接太多,现在打算新建单一数据表存放 join 关联后的数据。
出现的问题:若待 join 表中的某一个表中的字段做了修改,如何把结果及时同步到单一库中去
1
Jakesoft 2017-08-07 20:09:17 +08:00 via iPhone
触发器?
|
2
iffi OP 待 join 的表修改的操作由 php 来完成。 这个新建的单一数据表 主要由 Java 操作用于提供外界查询(里面的数据需要热数据,即 join 表的某一个表有变化,需要及时体现在这个用于聚合数据的单一表中去)
|
3
akira 2017-08-07 21:21:08 +08:00 1
|
4
sudoz 2017-08-07 21:25:58 +08:00 1
不建议使用 join
重新涉及库表 |
5
iffi OP 目前想到两个方案:
* 把 join 后的数据存放到 redis * 定时扫描修改记录(有数据 update_date 字段) |
6
Infernalzero 2017-08-07 22:43:48 +08:00
你这样还不如直接用 solr 或者 ES
实时性要求高一些的话就直接加冗余字段吧,再不济可以上 canal |
8
iffi OP @Infernalzero 没用过 solr 和 ES,我去了解下。另外,我发现用 redis 涉及到数据分页,第一种方案应该不可取
|
9
Infernalzero 2017-08-08 13:42:40 +08:00
redis 也可以做分页的
|
10
iffi OP @Infernalzero 看到了 lrange 但是还是觉得数据太大了。会把 redis 搞挂了
|