关 键 词:
近来在一个project中用到了pg(postgresql),客户需要很多表格,有些是典型的中国式报表(接触过的人都知道非常的复杂),所以分了两种方法解决:一、不需要用参数控制数据的,用view;二、需要用参数控制数据的用function;第一类比较简单,只要会sql就可以解决;第二类中,最复杂的是要进行数据处理的,(比如每页加入小计,最后要有合计的),查了一下资料,在8.3中有两种方法可以解决这个问题,现总结如下: 一、使用returen next 例子如下:
CREATE OR REPLACE FUNCTION fun1() RETURNS SETOF tbl AS
$
DECLARE
r tbl%rowtype;
BEGIN
FOR r IN SELECT * FROM tbl
LOOP
-- 进行处理
RETURN NEXT r; -- 返回当前选中的行
END LOOP;
RETURN;
END
$
LANGUAGE 'plpgsql' ;
SELECT * FROM fun1();二、使用return query(8.3中的新方法,据说性能要比上面的好)
CREATE OR REPLACE FUNCTION fun2() RETURNS SETOF tbl AS