zoukankan      html  css  js  c++  java
  • 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 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,...)

  • 相关阅读:
    GCC 里面的一些命令
    Servlet中的GET和POST之间的区别
    短暂的计算机职业生涯
    如何写详细设计文档
    exe4j打包jar文件成exe .
    android反编译问题
    OnScrollListener拖住主线程
    涵盖Android所有知识点的小实例
    屏蔽log
    sdk调低版本时,clean后失去R文件
  • 原文地址:https://www.cnblogs.com/zhangxp1129/p/2801195.html
Copyright © 2011-2022 走看看