gpt4 book ai didi

sql - 物化 View 未更新

转载 作者:行者123 更新时间:2023-11-29 12:07:43 25 4
gpt4 key购买 nike

我有一个物化 View ,它基本上跟踪结账时使用的所有优惠券,这样我就可以跟踪已使用了多少优惠券、还剩下多少优惠券等。我只是注意到物化 View 目前不会更新显示以下内容:

enter image description here

随着优惠券的使用,left 明显减少(优惠券类型和使用的优惠券以及使用它的用户 ID 位于不同的表中)。然而,它检测到一张优惠券已被使用,但至于我在测试中使用的另外两张优惠券,它不会从存储已用优惠券的表中提取它们并更新 MV。

以下是我目前制作 MV 的迁移的一部分:

exports.up = function(knex, Promise) {
return knex.schema
.raw(`
CREATE MATERIALIZED VIEW mv_vouchers as
SELECT v.voucher_id, v.quantity, COUNT(ov.voucher_id) AS "used", v.quantity - COUNT(ov.voucher_id) AS "left"
FROM public.vouchers v LEFT OUTER JOIN
public.order_vouchers ov
ON v.voucher_id = ov.voucher_id
GROUP BY v.voucher_id, v.quantity;
`);
};

我感觉我错误地使用了物化 View ,并且它只在迁移中运行了一次查询(当我最初实现 mv 时)。

编辑

有关更多信息,这里是我的其他 2 个表格:

优惠券:

enter image description here

订单优惠券:

enter image description here

最佳答案

MV 基本上只是一个表,但它还记得应该执行哪个查询来更新(实际上替换)其内容。

我认为 Postgres 没有 parameter for automatically refreshing the MV ,实时或定期。

当您创建 View 时,系统会查询并存储数据,除非您指定WITH NO DATA,在这种情况下,数据将创建为空。

然后,您可以通过调用 REFRESH MATERIALIZED VIEW 按需(重新)填充 View 。 .

关于sql - 物化 View 未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53207150/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com