MySQL join 问题

2017-08-07 20:03:07 +08:00
 iffi

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

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

另外,不建议用数据库的触发器。
sudoz
2017-08-07 21:25:58 +08:00
不建议使用 join
重新涉及库表
iffi
2017-08-07 22:10:11 +08:00
目前想到两个方案:
* 把 join 后的数据存放到 redis
* 定时扫描修改记录(有数据 update_date 字段)
Infernalzero
2017-08-07 22:43:48 +08:00
你这样还不如直接用 solr 或者 ES
实时性要求高一些的话就直接加冗余字段吧,再不济可以上 canal
syncher
2017-08-07 22:50:05 +08:00
@akira 为啥不建议触发器?
iffi
2017-08-08 09:46:37 +08:00
@Infernalzero 没用过 solr 和 ES,我去了解下。另外,我发现用 redis 涉及到数据分页,第一种方案应该不可取
Infernalzero
2017-08-08 13:42:40 +08:00
redis 也可以做分页的
iffi
2017-08-08 13:46:47 +08:00
@Infernalzero 看到了 lrange 但是还是觉得数据太大了。会把 redis 搞挂了

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

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

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

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

© 2021 V2EX