91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

金堂县| 克东县| 玉山县| 宁陕县| 新宾| 滦平县| 洛扎县| 仙桃市| 修武县| 大名县| 晴隆县| 泽州县| 秭归县| 彩票| 海宁市| 蒙自县| 报价| 化德县| 奉化市| 广州市| 三原县| 历史| 同仁县| 芮城县| 沁水县| 句容市| 乌拉特前旗| 新源县| 镇原县| 新和县| 囊谦县| 石渠县| 太康县| 积石山| 江阴市| 天气| 闽侯县| 旬阳县| 无为县| 道孚县| 滦南县|