8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

加速 postgres 中的 json 聚合

Julien P 2月前

13 0

我有一个简单的表,如下所示:| uid | search_qeury | search_ts ||-------|-----------------|-----------------------------------|| uid_1 | {\'key1&quo...

我有一张简单的表格,如下所示:

| uid   | search_qeury    | search_ts                         |
|-------|-----------------|-----------------------------------|
| uid_1 | {"key1":"val1"} | 2024-08-16 08:06:26.283557 +00:00 |
| uid_2 | {"key2":"val2"} | 2024-08-16 08:06:26.283557 +00:00 |

直接描述语言(DDL):

CREATE TABLE IF NOT EXISTS users_searches
(
    uid                varchar      NOT NULL,
    search_query       json         NOT NULL,
    search_ts          timestamptz  NOT NULL
);

我需要做的是将这些值聚合到一个包含以下列的新表中: uid , searching_4h , searching_8h , searching_12h

因此我编写了一个代码来按照以下方式实现该功能:

SELECT
    uid,
    JSON_AGG(search_query) FILTER (WHERE search_ts > CURRENT_TIMESTAMP - INTERVAL '4' HOUR)  AS searches_4h,
    JSON_AGG(search_query) FILTER (WHERE search_ts > CURRENT_TIMESTAMP - INTERVAL '8' HOUR)  AS searches_8h,
    JSON_AGG(search_query) FILTER (WHERE search_ts > CURRENT_TIMESTAMP - INTERVAL '12' HOUR) AS searches_12h
FROM users_searches
WHERE search_ts > CURRENT_TIMESTAMP - INTERVAL '12' HOUR
GROUP BY uid

但需要大约 10 分钟才能完成。我想知道是否有更优化的方法来实现这一点。谢谢

帖子版权声明 1、本帖标题:加速 postgres 中的 json 聚合
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Julien P在本站《postgresql》版块原创发布, 转载请注明出处!
最新回复 (0)
返回
作者最近主题: