加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在PostgreSQL中实现UPSERT的惯用方法

发布时间:2020-12-13 16:23:20 所属栏目:百科 来源:网络整理
导读:我已经阅读了PostgreSQL中不同的UPSERT实现,但所有这些解决方案相对较旧或相对具有异国情调(例如,使用 writeable CTE). 而且我根本不是一个psql专家,立刻就会发现,这些解决方案是否老旧,因为它们是推荐的,或者它们(好吧,几乎所有都是)只是不适合生产使用的玩
我已经阅读了PostgreSQL中不同的UPSERT实现,但所有这些解决方案相对较旧或相对具有异国情调(例如,使用 writeable CTE).

而且我根本不是一个psql专家,立刻就会发现,这些解决方案是否老旧,因为它们是推荐的,或者它们(好吧,几乎所有都是)只是不适合生产使用的玩具示例.

在PostgreSQL中实现UPSERT的最安全的方法是什么?

PostgreSQL现在有 UPSERT.

根据a similar StackOverflow question的优选方法目前如下:

CREATE TABLE db (a INT PRIMARY KEY,b TEXT);

CREATE FUNCTION merge_db(key INT,data TEXT) RETURNS VOID AS
$$
BEGIN
    LOOP
        -- first try to update the key
        UPDATE db SET b = data WHERE a = key;
        IF found THEN
            RETURN;
        END IF;
        -- not there,so try to insert the key
        -- if someone else inserts the same key concurrently,-- we could get a unique-key failure
        BEGIN
            INSERT INTO db(a,b) VALUES (key,data);
            RETURN;
        EXCEPTION WHEN unique_violation THEN
            -- do nothing,and loop to try the UPDATE again
        END;
    END LOOP;
END;
$$
LANGUAGE plpgsql;

SELECT merge_db(1,'david');
SELECT merge_db(1,'dennis');

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读