postgresql存储过程怎么写?

我已经用pg写了个简单的存储过程,但是,传递的参数太多,感觉写起来好辛苦啊,过程的功能是实现replaceinto[MYSQL]或者Mergeinto[ORACLE]下面... 我已经用pg写了个简单的存储过程,但是,传递的参数太多,感觉写起来好辛苦啊,

过程的功能是 实现replace into[MYSQL]或者 Merge into [ORACLE]

下面的这个是 网上找的demo:

CREATE FUNCTION merge_db(key INT, data TEXT) RETURNS VOID AS
$$
BEGIN
LOOP
UPDATE db SET b = data WHERE a = key;
IF found THEN
RETURN;
END IF;

BEGIN
INSERT INTO db(a,b) VALUES (key, data);
RETURN;
EXCEPTION WHEN unique_violation THEN
-- do nothing
END;
END LOOP;
END;
$$
LANGUAGE plpgsql;

然后我修改为了自己的,如下:
CREATE FUNCTION merge_db(key INT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT, data TEXT) RETURNS VOID AS
$$
BEGIN
。。。。。。。。。。。。。。。。
。。。。。。。。。。。。
。。。。。。

你可以看到,上面我复制了好多个, data TEXT, 因为我要用来处理的表,有100多个字段,如果都这样弄的话,我感觉这个好辛苦啊,大家有什么办法吗

100多个表,写存储过程 要写100多个参数,真不是人干的啊

求大神帮忙
是100多个字段 ,,,,,
展开
 我来答
jjxliu306
推荐于2016-12-01
知道答主
回答量:12
采纳率:0%
帮助的人:7.6万
展开全部
写个触发器 插入之前执行触发器

-- 创建一个测试表

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
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式