虽工作多年,但是sql的存储过程一致都没怎么用过,今天来按照博客https://www.cnblogs.com/applelife/p/11016674.html来学习一下(我使用postgre sql将这篇文章的例子都跑一遍)。
新建一张students表:
create table students(
id int primary key,
age int,
name varchar(20),
city varchar(20)
);
insert into students values(1, 22, '赵四', '杭州');
insert into students values(2, 16, '刘能', '上海');
insert into students values(3, 20, '谢广坤', '深圳');
insert into students values(4, 21, '刘美兰', '北京');
insert into students values(5, 20, '宋晓峰', '湖北');
insert into students values(6, 21, '谢大脚', '江苏');
insert into students values(7, 20, '苏玉红', '天津');
insert into students values(8, 21, '陈艳兰', '云南');
数据如图:
1.不带参数的存储过程
create or replace function getAllCount() returns integer as $$
declare
rlt_str varchar;
begin
select into rlt_str count(*) from students;
return rlt_str;
end
$$
language plpgsql;
然后执行这个存储过程:
select getAllCount();
注意:这个写法和mysql的差别还蛮大的;存储过程必须先执行一次,然后在随时的调用。
2.带参数的存储过程
drop function queryById(id int4, out s_name text, out s_city text);
create or replace function queryById(id int4, out s_name text, out s_city text)
returns setof record as
$$
declare
rec record;
begin
for rec in execute 'select * from students where id = '||$1 loop
s_name := rec.name;
s_city := rec.city;
return next;
end loop;
end;
$$
language plpgsql;
select * from queryById(1);
执行结果:
注意:这样查询记录还需要一个一个赋值;$1表示的是第一个参数; ||表示的字符串的拼接;record表示的是一条记录。
修改这个存储过程,查询出多个结果,这个时候是这样的。
create or replace function queryById(id int4, out s_name text, out s_city text)
returns setof record as
$$
declare
rec record;
begin
for rec in execute 'select * from students where age = '||$1 loop
s_name := rec.name;
s_city := rec.city;
return next;
end loop;
end;
$$
language plpgsql;
调用
select * from queryById(20);
执行结果:
总结:
pgsql的存储过程的一般写法:
CREATE OR REPLACE FUNCTION 函数名(参数名 参数类型,…)
RETURNS 返回值类型 AS
$BODY$
DECLARE
变量声明
BEGIN
函数体
END;
$BODY$
LANGUAGE ‘plpgsql’ VOLATILE;
手机扫一扫
移动阅读更方便
你可能感兴趣的文章