暂无图片
暂无图片
1
暂无图片
暂无图片
暂无图片

openGauss每日一练第15天 | 学习心得体会【少安】

原创 严少安 2021-12-16
1569

学习目标

学习openGauss定义存储过程和函数

课程学习

连接数据库

#第一次进入等待15秒 
#数据库启动中... 
su - omm 
gsql -r

1.创建存储过程

create table item(c1 int, c2 int); create procedure procedure_insert(a int, b int) as begin insert into item values(a, b); end; /

–查看存储过程
select * from pg_proc where proname = ‘procedure_insert’;

15_1.png

2.调用存储过程
select procedure_insert(1,100);
select * from item;

3.删除存储过程
drop procedure if exists procedure_insert;

4.创建函数
–创建一个函数func_add_sql,计算两个整数的和,并返回结果

CREATE FUNCTION func_add_sql(num1 integer, num2 integer) RETURN integer AS BEGIN RETURN num1 + num2; END; /

–查看函数定义
\sf func_add_sql
select * from pg_proc where proname = ‘func_add_sql’;

15_2.png

–按参数值传递。
CALL func_add_sql(1, 3);

–使用命名标记法传参。
CALL func_add_sql(num1 => 1,num2 => 3);
CALL func_add_sql(num2 := 2, num1 := 3);

–创建带出参的函数

CREATE FUNCTION func_increment_sql(num1 IN integer, num2 IN integer, res OUT integer) RETURN integer AS BEGIN res := num1 + num2; END; /

–出参传入常量
CALL func_increment_sql(1,2,1);

15_3.png

–创建返回RECORD类型的函数

CREATE OR REPLACE FUNCTION func_increment_sql1(i int, out result_1 bigint, out result_2 bigint) returns SETOF RECORD as $$ begin result_1 = i + 1; result_2 = i * 10; return next; end; $$language plpgsql; call func_increment_sql1(1, 0, 0);

5.修改函数定义
–重命名
ALTER FUNCTION func_add_sql(INTEGER, INTEGER) RENAME TO add_two_number;

6.删除函数
DROP FUNCTION add_two_number;
Drop function func_increment_sql1;
Drop function func_increment_sql;

15_4.png

课程作业

1.创建带有入参和出参的函数1,调用函数时使用按参数值传递和命名标记法传参
2.创建返回类型为record的函数2,重命名函数2
3.使用\sf和系统函数查看函数定义
4.删除函数

-- 1. create function func1 (num1 in int, num2 out int) return int as begin num2 := num1 + 100; end; / call func1(num1 => 10, num2 => 1); call func1(num1 := 20, num2 := 0); -- 2. create or replace function func2(num1 int, out res1 int, out res2 int) returns setof record as $$ begin res1 = num1 + 10; res2 = num1 + 100; return next; end; $$language plpgsql; call func2(1, 0, 0); alter function func2(int) rename to func2_1; -- 3. \sf func2_1 select * from pg_proc where proname = 'func2_1'; -- 4. drop function func1; drop function func2_1;

16_1.png

16_2.png

学习心得

课后作业第二题,至少需要一个out参数。重命名时只需要标记in参数的数据类型。

call func2(1, 0);
ERROR:  a column definition list is required for functions returning "record"
alter function func2(int, int, int) rename to func2_1;
ERROR:  function func2(integer, integer, integer) does not exist

参考文档

openGauss每日一练 | by 少安 | 汇总

openGauss产品文档 CREATE FUNCTION


松鼠镇楼,按时打卡
songshu1.jpg

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

文章被以下合辑收录

评论