亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PostgreSQL數據庫如果不存在則插入,存在則更新

發布時間:2020-10-21 09:20:38 來源:網絡 閱讀:22022 作者:青苗飛揚 欄目:數據庫


新遇到一個業務需求,往postgresql中插入數據的時候需滿足:如果數據庫存在這條記錄,則進行修改;不存在則進行插入。

Oracle中可以用merge來解決。Pg中之前沒做過類似操作,百度查了一下,PostgreSQL 9.5 版本帶來了一個新特性:UPSERTUPSERTINSERT, ON CONFLICT UPDATE的簡寫,簡而言之就是:插入數據,正常時寫入,主鍵沖突時更新。

示例來看一下:

一張測試表,結構如下:

yqm=# \d student;

           Table "public.student"

 Column |         Type          | Modifiers

--------+-----------------------+-----------

 id     | integer               |

 name   | character varying(20) |

Indexes:

    "id_cons" UNIQUE CONSTRAINT, btree (id)

目前數據如下:

yqm=# select * from student;

 id | name

----+------

  1 | a

  2 | b

  3 | c

(3 rows)

要插入的表要有一條唯一性約束,不然會報如下錯:

yqm=# insert into student values(4,'d') on conflict(id) do update set name='as';

ERROR:  there is no unique or exclusion constraint matching the ON CONFLICT specification

如果存在這種報錯,需要創建一條唯一性約束

yqm=# alter table student add constraint id_cons unique(id);

ALTER TABLE

再次插入

yqm=# insert into student values(4,'d') on conflict(id) do update set name='as';

INSERT 0 1

查看結果,已經新增了

yqm=# select * from student;

 id | name

----+------

  1 | a

  2 | b

  3 | c

  4 | d

(4 rows)

再次執行,會做更改操作

yqm=# insert into student values(4,'d') on conflict(id) do update set name='as';

INSERT 0 1

yqm=# select * from student;

 id | name

----+------

  1 | a

  2 | b

  3 | c

  4 | as

(4 rows)

 

 

 


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩留县| 南皮县| 晴隆县| 化州市| 白玉县| 广东省| 鲁山县| 海门市| 桃园县| 团风县| 马鞍山市| 陕西省| 莱阳市| 丰宁| 元氏县| 饶平县| 西吉县| 额敏县| 班玛县| 迁西县| 平谷区| 广平县| 治多县| 轮台县| 日土县| 洪江市| 雷波县| 祁东县| 桃源县| 永嘉县| 手机| 越西县| 砀山县| 迁西县| 清涧县| 始兴县| 航空| 盐源县| 衡水市| 广东省| 博客|