PostgreSQL 存储过程

PostgreSQL 存储过程定义格式如下:

■结构 PL/pgSQL是一种块结构的语言,比较方便的是用pgAdmin III新建Function,填入一些参数就可以了。

基本上是这样的:

CREATE OR REPLACE FUNCTION 函数名(参数1,[整型 int4, 整型数组 _int4, ...])  
RETURNS 返回值类型 
AS
$BODY$  
 DECLARE 变量声明  
 BEGIN 
   函数体  
 END;  
$BODY$  
LANGUAGE ‘plpgsql’ VOLATILE;


■变量类型 除了postgresql内置的变量类型外,常用的还有 RECORD ,表示一条记录。


■赋值 赋值和Pascal有点像:“变量 := 表达式;”  有些奇怪的是连接字符串的是“||”,比如 sql := ‘SELECT * FROM’ || table || ‘WHERE …’;


■判断   判断又和VB有些像:  IF 条件 THEN …  ELSEIF 条件 THEN …  ELSE …  END IF;


 ■循环   循环有好几种写法:  WHILE expression LOOP  

                                                                 statements  

                                                    END LOOP;  

              还有常用的一种是:(从1循环到9可以写成FOR i IN 1..9 LOOP)  

                                                    FOR name IN [ REVERSE ] expression .. expression LOOP  

                                                             statements  

                                                    END LOOP;

 ■其他   还有几个常用的函数:  SELECT INTO record …; 表示将select的结果赋给record变量(RECORD类型)  

                                                         PERFORM query; 表示执行query并丢弃结果  

                                                         EXECUTE sql; 表示执行sql语句,这条可以动态执行sql语句(特别是由参数传入构造sql语句的时候特别有用)


例1:无返回值

CREATE OR REPLACE FUNCTION 函数名称( 参数1,参数2,...)
   AS
$BODY$
DECLARE  --定义 
BEGIN
INSERT INTO "表名" VALUES(参数1,参数2,...);
END
$BODY$
LANGUAGE 'plpgsql' VOLATILE;  -- 最后别忘了这个。


例2:有返回值

CREATE OR REPLACE FUNCTION 函数名称(deptcode VARCHAR(20) ,deptname VARCHAR(60) ,pycode VARCHAR(60),isenabled CHAR(1))
RETURNS BOOLEAN  --返回值,布尔类型
AS
$body$
DECLARE
deptcode VARCHAR(20);
deptname VARCHAR(60);
pycode  VARCHAR(60);
isenabled CHAR(1);
BEGIN
UPDATE "deptDict" SET deptcode=deptcode,deptname=deptname,pycode=pycode,isenabled=isenabled,updatedhisdatetime=CURRENT_TIMESTAMP
WHERE deptcode=deptcode;
RETURN TRUE;  
END
$body$ 
LANGUAGE 'plpgsql' VOLATILE;


最后再加上如何执行这个存储过程(函数)

-- 执行存储过程方法1
SELECT * FROM 函数名称(参数1,参数2,...)
-- 执行存储过程方法2
SELECT  函数名称('0参数1,参数2,...)


转载自:http://blog.csdn.net/rgb_rgb/article/details/8654244

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值