1
yungeo 2021-12-31 13:55:13 +08:00
数据放到 ES 里做成 1 张大宽表试试?
|
2
xuelu520 2021-12-31 13:58:28 +08:00
2 个表,做一个视图?
|
3
wolfie 2021-12-31 13:59:51 +08:00
内存分页。
1 ~ 10 ,分别查 1 ~ 10 。 10 ~ 20 ,分别查 1 ~ 20 。 20 ~ 30 ,分别查 1 ~ 30 |
4
Habyss 2021-12-31 14:00:21 +08:00
不引入其他, 并且数据量适中, 单纯解决的话
1.两张表各查出前 n 条, 然后代码分页出[n-size, n] 2.数据库 union all, 也是两张表的前 n 条 union all |
5
wd 2021-12-31 14:00:33 +08:00 via iPhone
你这显然哪里做的聚合只能在哪里分页,你要在数据库聚合就简单了
|
6
lower 2021-12-31 14:02:41 +08:00 1
实在不行全扔给前端,让前端自己去分页……
|
7
VersionGod1 2021-12-31 14:14:39 +08:00
我遇到过这种问题,是用数据库的视图解决的,你可以试试
|
8
66beta 2021-12-31 14:30:54 +08:00
十几年前都是用视图,现在是不是流行存 redis ?
|
9
hay313955795 2021-12-31 15:11:48 +08:00
直接做视图不行?? 两个表。谁是谁的补充呢? 分页是分哪个表的数据呢?
你这里都没有说啊 |
10
lauix 2021-12-31 15:15:06 +08:00
都取出来,用代码在内存里进行汇总分查询
|
12
hj24 2021-12-31 16:23:56 +08:00 1
es 宽表,或者原数据库做一张聚合表是正解
|
13
mikicomo 2021-12-31 16:35:00 +08:00
两张表是否有主次之分?
如果有,并且分页查询条件是否都是取得主表的字段,那么先查完主表再关联查从表就好了。 如果没有,数据量小,无性能要求,视图 如果没有,数据量大,性能要求高,上 es (但是这样会有延迟问题,是否可接受) |
15
pengtdyd 2021-12-31 16:37:08 +08:00
一个好的架构师真的挺重要的
|
16
jtwor 2021-12-31 17:00:58 +08:00
同问,如果是按日期分表_yyyyMMdd ,大厂都是怎样分组合计做报表的
|
17
ankle306 2021-12-31 19:07:28 +08:00
查询如果是根据创建时间 /更新时间倒序,可以第一次查 a 表 10 条数据,b 表 10 条数据聚合,下一页让前段把最后一条数据的创建时间传到后段,查询 a 表在这个时间前的 10 条数据,b 表在这个时间前的 10 条数据,再聚合,依次类推。
|
18
llzzll1234 2021-12-31 22:58:43 +08:00
说用视图的,那跨库甚至跨实例你们要怎么搞?
|
19
DinnyXu 2021-12-31 23:05:18 +08:00
很简单。假设你 2 张表都在同一个数据库,那么可以使用 MySQL 函数 UNION ALL 进行聚合然后分页。
如果你 2 张表在不同的数据库,那么现在根据条件查出 A 库 A 表放入一个指定集合,再把 B 库 B 表根据条件查询出来放入指定集合。A 表和 B 表的集合必须是同一个泛型,然后再根据这个汇总的集合进行内存分页即可 |