Stored procedures in PostgreSQL

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

sql 复制代码
--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;
$$
sql 复制代码
---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;
$$
sql 复制代码
--返回值 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;
$$
相关推荐
志栋智能33 分钟前
超自动化巡检:知识沉淀与团队协作的新载体
大数据·运维·网络·数据库·人工智能·自动化
syt_biancheng1 小时前
Redis初识
数据库·redis·缓存
cmes_love1 小时前
股票逐笔level2历史行情下载十档订单薄五档tick分钟下载分享
数据库·区块链
仙俊红1 小时前
SQL 调优需要掌握的知识
数据库·sql
fofantasy2 小时前
NSK LH12AN 微型导轨技术手册
运维·网络·数据库·经验分享·规格说明书
杨运交2 小时前
[032][缓存模块]基于Redis Bitmap的用户行为统计实战:签到与日活分析
数据库·redis·缓存
一 乐2 小时前
家政服务管理系统|基于springboot + vue家政服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·家政服务管理系统
努力成为AK大王4 小时前
并发编程的核心挑战、优化方案与核心知识点总结
java·开发语言·数据库
En^_^Joy5 小时前
Django开发:模板系统入门指南
数据库·django·sqlite