首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在PostgreSQL-11中有条件地更新字段

在PostgreSQL-11中有条件地更新字段
EN

Stack Overflow用户
提问于 2019-09-14 23:43:46
回答 1查看 83关注 0票数 1

给定以下查询:

代码语言:javascript
复制
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

但是,如果我通过在表名前面加上如下所示的方式完全指定该字段:

代码语言:javascript
复制
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值的表达式可以包含对其他字段的引用,以获得对旧值的访问:

表达式 要分配给列的表达式。表达式可以使用表中此列和其他列的旧值。

那我做错什么了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-15 00:22:30

使用表别名

代码语言:javascript
复制
WHEN s.offline_access_token ...

使用别名时,表名不可见。与此无关,您可能应该使用IS NOT DISTINCT FROM而不是==

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57940077

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档