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

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
$$
beginselect 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 $$
BEGINRETURN QUERY(SELECT * FROM geovindu);
END;
$$ LANGUAGE plpgsqlselect * from fungeovindu();-- 查询DROP PROCEDURE IF EXISTS procSelectSchoolCREATE 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.lryc.cn/news/479846.html

相关文章:

  • 第10章 多表查询
  • 【基于LSM的ELF文件安全模块设计】参考
  • 全卷积和全连接
  • Unity图形学之Shader结构
  • 离散时间信号的产生
  • 物联优化汽车齿轮锻造
  • CocosCreator 构建透明背景应用(最新版!!!)
  • 使用CentOS宝塔面板docker搭建EasyTier内网穿透服务
  • HTMLCSS: 实现可爱的冰墩墩
  • 天地图入门|标注|移动飞行|缩放,商用地图替换
  • Flutter PC端UI组件库
  • NVR小程序接入平台/设备EasyNVR多品牌NVR管理工具/设备汇聚公共资源场景方案全析
  • 干部谈话考察系统:革新传统,精准高效
  • 反转链表(Leetcode)
  • 制作游戏外挂的技术栈有哪些
  • python下载pdf
  • 我们来学mysql -- 同时使用 AND 和 OR 查询错误(填坑篇)
  • 关于Websocket
  • vue2 pdf 链接地址打开
  • c# 动态lambda实现二级过滤(多种参数类型)
  • 34.Redis事务
  • 认识类和对象
  • 解决echarts桑基图为0时tooltip不显示的问题
  • vue3 基础笔记
  • Oracle 第30章:最佳实践与案例研究
  • 第九周预习报告
  • 【分享】这篇教程助力你成为 JavaScript 糕手!(四)
  • 双亲委派模型的破坏
  • Android关机流程知多少?
  • 深入理解指针end(总结篇)