postgresql 實(shí)現(xiàn)replace into功能的代碼
PostgreSQL 9.5-
使用函數(shù)或with實(shí)現(xiàn)
create table test(id int primary key, info text, crt_time timestamp); with upsert as (update test set info='test',crt_time=now() where id=1 returning *) insert into test select 1,'test',now() where not exists (select 1 from upsert where id=1);
PostgreSQL 9.5+
PostgreSQL 9.5 引入了一項(xiàng)新功能,UPSERT(insert on conflict do),當(dāng)插入遇到約束錯(cuò)誤時(shí),直接返回,或者改為執(zhí)行UPDATE。
INSERT INTO table_name VALUES() ON conflict (唯一索引字段) DO UPDATE ...
補(bǔ)充:PostgreSQL中select into用法總結(jié)
在普通的sql中,postgresql支持seelct......into......
但是動(dòng)態(tài)調(diào)用時(shí)候不支持select......into......
比如:
create or replace FUNCTION test () RETURNS void AS $body$ DECLARE toalnum int; BEGIN execute 'select sum(colname) into totalnum'; return; END; $body$ LANGUAGE 'plpgsql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;
以上情況會(huì)報(bào)錯(cuò)。。。。。
因該修改為如下
create or replace FUNCTION test () RETURNS void AS $body$ DECLARE toalnum int; BEGIN execute 'select sum(colname)' into totalnum; return; END; $body$ LANGUAGE 'plpgsql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
postgresql 循環(huán)函數(shù)的簡(jiǎn)單實(shí)現(xiàn)操作
這篇文章主要介紹了postgresql 循環(huán)函數(shù)的簡(jiǎn)單實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
postgresql數(shù)據(jù)庫(kù)表ID自增的實(shí)現(xiàn)代碼
postgresql數(shù)據(jù)庫(kù)可以創(chuàng)建主鍵,但是沒(méi)有像mysql那樣直接指定主鍵自增的auto_increment關(guān)鍵字,因此如果在postgresql中創(chuàng)建表指定主鍵自增使用auto_increment會(huì)報(bào)錯(cuò),本文通過(guò)一個(gè)實(shí)例給大家演示自增ID的實(shí)現(xiàn),需要的朋友可以參考下2023-12-12
Mybatis調(diào)用PostgreSQL存儲(chǔ)過(guò)程實(shí)現(xiàn)數(shù)組入?yún)鬟f
這篇文章主要介紹了mybatis調(diào)用postgresql自定義函數(shù)傳遞數(shù)組參數(shù)的解決方案,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
PostgreSQL 使用raise函數(shù)打印字符串
這篇文章主要介紹了PostgreSQL 使用raise函數(shù)打印字符串,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
postgresql 賦權(quán)語(yǔ)句 grant的正確使用說(shuō)明
這篇文章主要介紹了postgresql 賦權(quán)語(yǔ)句 grant的正確使用說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
postgresql insert into select無(wú)法使用并行查詢的解決
這篇文章主要介紹了postgresql insert into select無(wú)法使用并行查詢的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01

