用户登录
用户注册

分享至

postgresql执行存储过程

  • 作者: 挥泪迎风尿
  • 来源: 51数据库
  • 2020-09-28
写个触发器 插入之前执行触发器

-- 创建一个测试表

create table test(id int primary key , name varchar(50));

-- 触发器 插入前ID如果已经存在则替换name的值
CREATE OR REPLACE function _replace() RETURNS TRIGGER AS $INSERT$

declare

_has int ;

BEGIN

select id from test where id = NEW.id into _has;

raise notice 'ddd:%' , _has;

if _has > 0 then
update test set name = NEW.name where id = NEW.id;

RETURN null;

end if;

return NEW;

END;

$INSERT$

LANGUAGE PLPGSQL;

-- 给表加上触发器
CREATE TRIGGER tbefore BEFORE INSERT ON test FOR EACH ROW EXECUTE PROCEDURE _replace();

-- 插入两个值
insert into test(id , name) values(1,'1');
insert into test(id , name) values(1,'6');

select * from test;

结果:

pumpkin=> select * from test;
id | name
----+------
1 | 6
(1 行记录)

时间:1.474 ms



  postgresql的pl/pgsql语言是支持动态sql语句的(说execute immediate的是ecpg所支持的)。但是,要记得重要的一点: 是在pl/pgsql语言中支持。而pl/pgsql语言一个块结构的语言,它以begin ... end为块的开始与结束标识。这也就是说,要执行动态sql语句,就必须放到begin ... end块中,而不要想实现一个单独的动态sql语句。在sql server中,倒是可以轻松的实现,我们可以直接执行一个这样的动态sql:
execute?sp_executesql?n'select?1?as?val'而在postgresql中,就不要有此想法了。当然,sql server的这种动态sql语句的执行方法也有其局限与不便的地方。
在pl/pgsql中,执行动态sql的格式如下(摘录自说明文档):
execute?command-string?[?into?[strict]?target?]?[?using?expression?[,?...?]?];其中,
command-string就是要执行的动态sql语句(一定要记住:这里是sql语句,不是pl/pgsql语句,像raise notice就不能使用);
into子句是把sql查询到的值赋给into指定的变量;
using子句是前面的command-string中替代变量($1, $2, ...)的赋值;
示例:
do?$$
declare
v_c1?integer;
v_c2?integer;
begin
execute?'select?count(*)?as?c1,?count(*)?as?c2?from?(select?1?as?idx?union?select?11?as?idx?union?select?21?as?idx)?s?where?idx?>?$1'?
into?v_c1,?v_c2
using?10;
raise?notice?'%,?%',?v_c1,?v_c2;
软件
前端设计
程序设计
Java相关