加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL 存储过程

发布时间:2020-12-13 18:21:36 所属栏目:百科 来源:网络整理
导读:PostgreSQL 存储过程定义格式如下: ■结构 PL/pgSQL是一种块结构的语言,比较方便的是用pgAdmin III新建Function,填入一些参数就可以了。 基本上是这样的: CREATE OR REPLACE FUNCTION 函数名(参数1,[整型 int4,整型数组 _int4,...]) RETURNS 返回值类型

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,...)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读