百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

PostgreSQL的函数和存储过程

xsobi 2024-12-01 05:36 1 浏览

简介

PostgreSQL是最流行的对象关系型数据库系统。它是一个强大的、高性能的数据库系统。在这篇文章中,我们将讨论如何使用函数和存储过程来执行操作,如插入、删除、更新和查询。感兴趣的同学可以通过 MemFireDB一边操作一边阅读。

函数

一般来说,函数是一组进行任何操作的SQL语句,如选择、插入、删除和更新。在PostgreSQL中有两种类型的函数 "系统定义的函数 "和 "用户定义的函数"。在这篇文章中,我们讨论用户定义的函数。

函数语法

CREATE OR REPLACE FUNCTION function_name (parameters-list)
RETURNS return_type
LANGUAGE plpgsql
AS
$
    DECLARE
    --- variables
    BEGIN
        --- SQL statements (logic)
    END
$

优势

你可以在一个函数中拥有多个SQL语句,你可以返回任何类型的结果,如一个表或一个单一的值(整数,varchar,日期,时间戳,等等)。

限制

你不能在函数中使用事务。

存储过程

为了克服函数的限制,PostgreSQL提供了存储过程来支持事务。在存储过程中,我们可以启动、提交、回滚事务。然而,存储过程不能像表一样返回一个结果集。它只能返回INOUT参数。

语法

CREATE OR REPLACE PROCEDURE procedure_name (parameters-list)
LANGUAGE plpgsql
AS
$
DECLARE
--- Variables
BEGIN

    --- SQL statements (logic)

END
$

创建数据库

我们这里使用 memfiredb.com 登录之后点击创建数据库,输入相应的信息就可以完成数据库的创建了:

创建完数据库后,下载一个推荐的客户端,参照教程连接数据库。https://community.memfiredb.com/topic/47/%E5%A6%82%E4%BD%95%E4%B8%8B%E8%BD%BDwindows%E5%AE%A2%E6%88%B7%E7%AB%AF-dbeaver

建表

让我们使用以下SQL脚本在testdb数据库中创建Employees表:

CREATE TABLE Employees
(
    Id serial,
    Name VARCHAR(100),
    DateOfBirth Date,
    City VARCHAR(100),
    Designation VARCHAR(100),
    JoiningDate Date
)

存储过程创建及使用

参数类型

在创建存储过程和函数之前,让我们先看一下参数的类型,有三种类型的参数,我们可以在函数和存储过程中使用。

  • IN
  • OUT
  • INOUT

IN

IN代表一个输入参数。它用于在函数或存储过程中传递数值,如果我们不在参数名称后面使用IN关键字,默认情况下所有的参数都是输入类型。

OUT

OUT代表输出类型的参数。它返回值;你可以把它作为空值传递,也可以不初始化,因为这些类型的参数只用于从函数和存储过程中设置和返回值。

INOUT

INOUT代表输入和输出类型的参数,这些类型的参数可以用来传递值,也可以从一个函数或存储过程中返回值。

创建存储过程

使用下面的脚本来创建一个名为 "AddEmployee "的存储过程。这将在Employees表中插入信息。

CREATE OR REPLACE PROCEDURE AddEmployee
(
    EmpId INOUT INT,
    EmpName VARCHAR(100),
    EmpDob DATE,
    EmpCity VARCHAR(100),
    EmpDesignation VARCHAR(100),
    EmpJoiningDate DATE
)
LANGUAGE plpgsql AS
$
BEGIN
   INSERT INTO Employees (Name,DateOfBirth,City,Designation,JoiningDate) VALUES
    (EmpName,
     EmpDob,
     EmpCity,
     EmpDesignation,
     EmpJoiningDate
    ) RETURNING Id INTO EmpId;
END
$;

然后执行一下该存储过程,将信息插入到Employees表中:

CALL AddEmployee(null,'Peter Parker','1997-10-01','New York' ,'Web Developer','2020-11-01');

然后我们执行命令,检查一下是否有数据插入到表中:

SELECT * FROM Employees;

接下来我们将创建一个存储过程来更新Employees记录:

CREATE OR REPLACE PROCEDURE UpdateEmployee
(
    EmpId INT,
    EmpName VARCHAR(100),
    EmpDob DATE,
    EmpCity VARCHAR(100),
    EmpDesignation VARCHAR(100),
    EmpJoiningDate DATE
)
LANGUAGE plpgsql AS
$
BEGIN
   UPDATE Employees SET
   Name = EmpName,
   DateOfBirth = EmpDob,
   City = EmpCity,
   Designation = EmpDesignation,
   JoiningDate = EmpJoiningDate
   Where Id = EmpId;
END
$;

我们试着执行一下:

CALL UpdateEmployee(1,'Peter S Parker','1999-10-01','New York' ,'Web Developer','2020-11-01');

我们已经创建了能执行插入和更新的存储过程,现在我们将创建一个存储过程,使我们能够删除Employees中的记录。

CREATE OR REPLACE PROCEDURE DeleteEmployee
(
    EmpId INT
)
LANGUAGE plpgsql AS
$
BEGIN
    DELETE FROM Employees WHERE Id = EmpId;
END
$;

执行该存储过程:

CALL DeleteEmployee(2);

会删除id是2的记录。上面我们演示了如何使用存储过程,接下来我们将演示如何创建和使用函数。

函数创建及使用

先看一个简单的例子:

CREATE OR REPLACE FUNCTION GetAllEmployees()
RETURNS Employees
LANGUAGE SQL
AS
$
    SELECT * FROM Employees;
$;

然后我们试着执行下面的语句:

SELECT * FROM GetAllEmployees();

上面的select语句会从GetAllEmployees函数的返回结果中进行查询。下面是一个可以接受输入参数的例子:

CREATE OR REPLACE FUNCTION GetEmployeeById(EmpId INT)
RETURNS Employees
LANGUAGE SQL
AS
$
    SELECT * FROM Employees WHERE Id = EmpId;
$;

执行:

SELECT * FROM GetEmployeeById(3);

再看一个例子,我们正Employees表中有一个出生日期字段,所以让我们创建一个函数来根据出生日期返回年龄。这里用到了一个系统内置的age函数来计算年龄,它接受两个参数:当前日期和出生日期。它通过计算差值来返回年龄。

CREATE OR REPLACE FUNCTION GetEmployeeAge(EmpId INT, Age OUT VARCHAR(100))
LANGUAGE plpgsql
AS
$
BEGIN
    SELECT AGE(NOW()::Date,DateOfBirth) into Age FROM Employees WHERE Id = EmpId;
END;
$

上面定义的GetEmployeeAge函数包含两个参数,其中EmpId是int类型的输入参数,Age则是varchar类型的输出参数,所以,该函数的调用方法如下:

SELECT * FROM GetEmployeeAge(1);

总结

当我们需要返回单值结果或表格式结果时,函数是一个很好的选择。如果你想启动一个事务,提交或回滚多个SQL语句,那么存储过程是最佳选择。

相关推荐

【互联网那些事】高效开发Android App的10个建议

  假如要GooglePlay上做一个最失败的案例,那最好的秘诀就是界面奇慢无比、耗电、耗内存。接下来就会得到用户的消极评论,最后名声也就臭了。即使你的应用设计精良、创意无限也没用。  耗电或者内存...

手机APP开发方式有哪些? 手机app的开发模式有哪三种?

微信小程序开发定制_软件开发_APP开发_网站制作-优软软件开发...

Android开发入门(一):Android系统简介

Android系统是Google公司在2008年推出的一款智能移动设备操作系统,通过不断地版本迭代,目前已经推出到Android11版本了。Android系统广泛应用在手机、平板、电视等各种电子设...

物联网app开发流程 物联网app开发工具

现在随着科技的发展,很多产品都想用一个手机app去显示他的参数数据或者通过手机app去控制它。但是很多人不知道他的流程。今天我就来说下物联网app开发流程。首先需要把物联网app开发流程分2个步骤,一...

Android开发进阶 | 如何学习 Android Framework?

大部分有“如何学习Framework源码”这个疑问的,应该大都是应用层开发。应用层是被Framework层调用执行的,知道自己的代码是怎么被调用的,才能理解程序的本质,理解本质有助于解决遇到的...

快速实现APP混合开发(Hybrid App开发)攻略

前言:...

三个阶段带你了解一款app开发的完整流程

第一个阶段需求阶段:1.需求讨论--开发类型、开发平台、具体的产品功能需求、项目预计完成时间、预算2.需求评估--确认合作后评估具体的预算3.界面设计--设计部门进行产品界面设计,形成效果图...

Android 开发中文引导-应用小部件

应用小部件是可以嵌入其它应用(例如主屏幕)并收到定期更新的微型应用视图。这些视图在用户界面中被叫做小部件,并可以用应用小部件提供者发布。可以容纳其他应用部件的应用组件叫做应用部件的宿主(1)。下面的截...

手机软件开发从零开始【Android第2篇Hello】

Hello,朋友们我们又见面了。上一篇我们讲到了《Android开发环境搭建【Android基础第1篇】》,错过的朋友可以点击文章末尾的“阅读原文”查看。另外需要下载JDK和ADT-bundle工具的...

「全栈工程师之梦的开始--安卓开发(二)」开发安卓app

在配置好jdk开发环境、安装好开发工具Androidstudio后,我们就可以开始开发安卓app了。首先,我们需要先了解下android的术语。...

二、Android界面开发 android 开发

学习目标了解Android常用布局了解Android常用控件...

如何开发一款APP既快捷也简便 开发一款app的步骤

具体较为简单的步骤可以选择用androidstudio开发app1、打开软件,在菜单中选择file-》newproject打开创建向导。2、配置项目,确定各个名称和存放项目的存放路径;Applic...

安卓开发中的“Android高手”,需要具备哪些技术?

前言成为一名安卓开发者很容易,但是要成为一名“Android高手”却不那么容易;...

移动开发(一):使用.NET MAUI开发第一个安卓APP

对于工作多年的C#程序员来说,近来想尝试开发一款安卓APP,考虑了很久最终选择使用.NETMAUI这个微软官方的框架来尝试体验开发安卓APP,毕竟是使用VisualStudio开发工具,使用起来也...

微软推出PowerApps:零基础开发Win10/iOS/安卓企业应用

IT之家讯微软今天面向企业宣布了全新的应用开发解决方案PowerApps,让Windows(包括Win10)、iOS以及安卓应用的开发和分发变得更加简单。PowerApps的用户界面与Office办...