如何在postgresql中实现一个replaceinto功能-创新互联
如何在postgresql中实现一个replace into功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
创新互联公司于2013年开始,先为瓮安等服务建站,瓮安等地企业,进行企业商务咨询服务。为瓮安企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。PostgreSQL 9.5-
使用函数或with实现
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 引入了一项新功能,UPSERT(insert on conflict do),当插入遇到约束错误时,直接返回,或者改为执行UPDATE。
INSERT INTO table_name VALUES() ON conflict (索引字段) DO UPDATE ...
补充:PostgreSQL中select into用法总结
在普通的sql中,postgresql支持seelct......into......
但是动态调用时候不支持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;
以上情况会报错。。。。。
因该修改为如下
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;
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联网站建设公司,的支持。
当前名称:如何在postgresql中实现一个replaceinto功能-创新互联
文章URL:http://pwwzsj.com/article/hicjp.html