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;
$$
相关推荐
Σίσυφος190022 分钟前
PCL法向量估计 之 方向约束法向量(Orientation Guided Normal)
数据库
老毛肚25 分钟前
手写mybatis
java·数据库·mybatis
海山数据库31 分钟前
移动云大云海山数据库(He3DB)postgresql_anonymizer插件原理介绍与安装
数据库·he3db·大云海山数据库·移动云数据库
l1t31 分钟前
DeepSeek总结的PostgreSQL的GPT推理SQL移植到DuckDB的性能优化方法
sql·gpt·postgresql
云飞云共享云桌面34 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
2501_9279935342 分钟前
SQL Server 2022安装详细教程(图文详解,非常详细)
数据库·sqlserver
星火s漫天43 分钟前
第一篇: 使用Docker部署flask项目(Flask + DB 容器化)
数据库·docker·flask
xcLeigh1 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
威迪斯特1 小时前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
xu_yule1 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式