xlfm22 发表于 2016-11-21 08:38:37

PostgreSQL 存储过程

  写这篇文正的来源是这样的,在开发中使用到PostgreSQL数据库,编写存储过程时遇到一些问题和SQLServer还有点区别,在此就顺手写在了博客上,后备无患。
  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 LOOPstatementsEND LOOP;还有常用的一种是:(从1循环到9可以写成FOR i IN 1..9 LOOP)FOR name IN [ REVERSE ] expression .. expression LOOPstatementsEND 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);
pycodeVARCHAR(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,...)
页: [1]
查看完整版本: PostgreSQL 存储过程