当前位置: 首页 > article >正文

Stored procedures in PostgreSQL

select 存储过程,在现了解的情况,还是没有mysql,sqlserver等好写好用。

--postgreSQL 11.0 以下版本
create or replace FUNCTION procInsertSchool
(
    pSchoolId Char(5),
    pSchoolName VarChar(100),
    pSchoolTelNo VarChar(8)
)
RETURNS void
language plpgsql
as $$
begin
IF NOT EXISTS (SELECT * FROM School WHERE SchoolId=pSchoolId)  then-- 存在相同的名称不添加  and SchoolId=@SchoolId  and SchoolName=@SchoolName
INSERT INTO School
(
    SchoolId ,
    SchoolName ,
    SchoolTelNo
)
    VALUES
(
    pSchoolId ,
    pSchoolName ,
    pSchoolTelNo
);
end if;
end;
$$
---postgreSQL 11.0 以上版本
DROP PROCEDURE IF EXISTS procInsertSchoolOutput;

CREATE PROCEDURE procInsertSchoolOutput
(
    pSchoolName NVarChar(5),
    pSchoolTelNo VarChar(500),
    pSchoolId int  inout
)
language plpgsql
as $$
begin
IF NOT EXISTS (SELECT * FROM School WHERE SchoolName=pSchoolName)    -- 如果存在相同的记录,不添加
INSERT INTO School
(
    SchoolName,
    SchoolTelNo
)
    VALUES
(
    pSchoolName ,
    pSchoolTelNo
 
);
 
end;
$$
--返回值 inout
create or replace procedure geovindustat(
   inout total int default 0
)
as
$$
begin
  select count(*) into total from geovindu;
end;
$$
language plpgsql;
 
call geovindustat();
 
 
-- 函数查询
CREATE OR REPLACE FUNCTION fungeovindu()
RETURNS table(tid int,tname varchar(50),TelNo varchar(11))
AS $$
BEGIN
    RETURN QUERY(SELECT * FROM geovindu);
END;
$$ LANGUAGE plpgsql
 
select * from fungeovindu();

-- 查询
 
DROP PROCEDURE IF EXISTS procSelectSchool
 
CREATE or replace PROCEDURE procSelectSchool
(
    pStudentId char(5)
)
language plpgsql SECURITY DEFINER
as $$
DECLARE schoolrow record;
begin
for schoolrow in (SELECT * FROM School WHERE SchoolId = pStudentId)
    loop
RAISE NOTICE 'Id is : % , SchoolName is : %', schoolrow."SchoolId",schoolrow."SchoolName"
    end loop;
end;
$$


http://www.kler.cn/a/385661.html

相关文章:

  • rust模式和匹配
  • 数据分析——学习框架
  • 【Linux】常用命令(2.6万字汇总)
  • sqlite更新
  • 最新网盘资源搜索系统,电视直播,Alist聚合播放
  • 支持 Win10 的网络环境模拟(丢包,延迟,带宽)
  • C++入门基础知识142—【关于C++ 友元函数】
  • 国产操作系统ctyun下安装Informix SDK开发包的方法
  • Notepad++ 更改字体大小和颜色
  • [每周一更]-(第122期):模拟面试|数据库面试思路解析
  • 类文件结构详解
  • Leecode热题100-543.二叉树的直径
  • 【C++练习】生成并打印所有可能的三色组合
  • 组队学习首次开放许愿啦!下个月想学什么,听你的
  • C 语言函数指针 —— 实现程序分层
  • 腾讯为什么支持开源?
  • SpringMVC执行流程与运行原理解析
  • 智能提醒助理系列-springboot项目彩虹日志+TraceID
  • 基于单片机的智能家居安防系统设计
  • Vite与Vue Cli的区别与详解
  • 985研一学习日记 - 2024.11.8
  • 浅谈绝缘测试以及压缩电机应用
  • 青少年学习倦怠测评
  • 算法(第一周)
  • 鸿蒙ArkTS中的获取网络数据
  • Golang | Leetcode Golang题解之第551题学生出勤记录I