中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

洪江市| 商洛市| 都安| 十堰市| 岫岩| 通海县| 那曲县| 洛川县| 平乐县| 韶关市| 定南县| 绩溪县| 鹤岗市| 综艺| 富源县| 讷河市| 福州市| 大新县| 和林格尔县| 古交市| 垦利县| 永靖县| 常熟市| 扶沟县| 田阳县| 天津市| 乌审旗| 通化县| 桓台县| 郧西县| 德兴市| 和林格尔县| 雷波县| 镇远县| 东丽区| 古田县| 勐海县| 黄平县| 吉安县| 竹北市| 六安市|