给定以下查询:
insert into shopify_app_shops as s
(
myshopify_name,
hostname,
user_status,
offline_access_token,
offline_access_token_updated_at,
updated_at
)
values
(
%(myshopify_name)s,
%(hostname)s,
%(user_status)s,
%(offline_access_token)s,
now(),
now()
)
on conflict (myshopify_name)
do update
set
hostname=%(hostname)s,
user_status=%(user_status)s,
offline_access_token_updated_at =
CASE
WHEN offline_access_token == %(offline_access_token)s
THEN offline_access_token_updated_at
ELSE now()
END,
offline_access_token=%(offline_access_token)s,
updated_at = now()
returning myshopify_name
;我知道错误:
失败:列引用" offline_access_token“是不明确的第28行:offline_access_token == NULL
但是,如果我通过在表名前面加上如下所示的方式完全指定该字段:
WHEN shopify_app_shops.offline_access_token == %(offline_access_token)s相反,我得到了这个错误:
失败:对表"shopify_app_shops“的FROM-子句条目的引用无效,第28行: shopify_app_shops.offline_access_token == NULL
此时,我不知所措,不知该怎么办!
postgresql-11更新语句的文档清楚地指出,用于set值的表达式可以包含对其他字段的引用,以获得对旧值的访问:
表达式 要分配给列的表达式。表达式可以使用表中此列和其他列的旧值。
那我做错什么了?
发布于 2019-09-15 00:22:30
https://stackoverflow.com/questions/57940077
复制相似问题