PLSQL: 存储过程,用户自定义函数[oracle]
注意: raise notice是高斯的输出语句; DBMS_OUT_PUT.PUT_LINE是oracle的输出语句
存储过程 Stored Procedure
存储过程可以封装数据访问逻辑,使得应用程序可以通过调用存储过程来执行这些逻辑,而不是直接执行SQL语句。这有助于提高代码的可重用性、可维护性和安全性
命名规范
使用下划线分隔单词
使用前缀 sp_或 p_等
可读性: 使用有意义的名称
语法: 创建存储过程
CREATE OR REPLACE PROCEDURE procedure_name [pramaters]
IS/AS -- 变量声明
BEGIN-- 存储过程的主体-- 可以包含SQL语句和PL/SQL代码
exception--异常处理
END procedure_name;
CREATE OR REPLACE:创建或者替换,当存储过程修改的时候,编译后会覆盖掉原来的同名的存储过程
参数:
参数类型不需要写长度,参数名不要和存储过程当中定义的变量重名
IN:从外边(调用存储过程的地方)把值传到存储过程内部,默认的参数类型
[in] 参数名 参数类型
命名规范:p_(或者i_)开头
在存储过程中,对 IN 类型参数的值进行修改,新修改的值 只在存储过程内部有效
OUT:把存储过程当中计算(获取)到的值传到外边(调用存储过程的地方)
OUT 参数名 参数类型
命名规范:o_ 开头
INOUT:可以通过 INOUT 参数把 值传到 存储过程中,也可以把值从存储过程传出来,不常使用
INOUT 参数名 参数类型

-- 存储过程在创建的时候,只是编译,不会执行,调用存储过程的时候才会执行
-- 调用存储过程,从数据库中将存储过程调用出来,并且会执行里面的代码
-- 无参存储过程
-- 案例1:编写存储过程,获取员工编号为7788的员工的姓名和工资,并打印出来
CREATE OR REPLACE PROCEDURE sp_output_emp
IS
DECLAREv_ename emp.ename%TYPE;v_sal emp.sal%TYPE;
BEGINSELECT ename, sal INTO v_ename, v_sal FROM emp WHERE empno=7788;RAISE NOTICE '7788的姓名是:%,工资是:%', v_ename, v_sal;
EXCEPTIONWHEN OTHERS THENRAISE NOTICE '发生异常!';RAISE NOTICE '异常代码:%', SQLSTATE;RAISE NOTICE '异常信息:%', SQLERRM;
END;
-- 简单调用
CALL sp_output_emp(); -- 调用存储过程的名字( );
CALL sp_output_emp1(5566);

有参存储过程(in)
-- 案例2:对案例1进行修改,增加传入参数,查询指定传入员工编号的员工姓名和工资,并打印
CREATE OR REPLACE PROCEDURE sp_output_emp1 (i_empno int)
IS
DECLAREv_ename emp.ename%TYPE;v_sal emp.sal%TYPE;
BEGINSELECT ename, sal INTO v_ename, v_sal FROM emp WHERE empno=i_empno;RAISE NOTICE '7788的姓名是:%,工资是:%', v_ename, v_sal;
EXCEPTIONWHEN OTHERS THENRAISE NOTICE '发生异常!';RAISE NOTICE '异常代码:%', SQLSTATE;RAISE NOTICE '异常信息:%', SQLERRM;
END;
调用存储参数: 如上和无参调用完全想同
有参存储过程(in 和 out)
例3:在案例2的基础上继续进行修改,增加传出参数,将查询出来的员工姓名和工资,向外传递
CREATE OR REPLACE PROCEDURE sp_output_emp2(IN i_empno int,OUT o_ename emp.ename%TYPE,
OUT o_sal emp.sal%type)
IS
DECLAREv_ename emp.ename%TYPE;v_sal emp.sal%TYPE;
BEGINSELECT ename, sal INTO v_ename, v_sal FROM emp WHERE empno=i_empno;o_sal := v_sal;o_ename := v_ename;i_empno := 99666;--RAISE NOTICE '7788的姓名是:%,工资是:%', v_ename, v_sal;
EXCEPTIONWHEN OTHERS THENRAISE NOTICE '发生异常!';RAISE NOTICE '异常代码:%', SQLSTATE;RAISE NOTICE '异常信息:%', SQLERRM;
END;

使用匿名块调用存储过程时需要输出语句的原因在于,存储过程的输出参数(OUT参数)不会自动显示其值,它们是“静默”的,即不会像函数返回值那样直接返回。因此,为了查看存储过程的执行结果,需要在调用存储过程的匿名块中使用输出语句来显示这些值。
如果 RAISE NOTICE '7788的姓名是:%, 工资是:%', v_ename, v_sal; 没有被注释掉,那么在使用匿名块调用存储过程时,不需要额外的输出语句来显示这些信息。因为 RAISE NOTICE 语句会直接将信息输出到数据库的日志或控制台。
有参存储过程(in out)
CREATE OR REPLACE PROCEDURE update_value (in out p_value NUMBER
) AS
BEGIN-- 对传入的值进行操作,例如增加10p_value := p_value + 10;
END;
/
调用存储过程

输出: 10

输出: 15
注意: raise notice是高斯的输出语句; DBMS_OUT_PUT.PUT_LINE是oracle的输出语句
有参存储过程(out)

函数function
函数的分类

用户自定义函数
它允许用户根据需要定义新的操作和计算, 通常使用PL/SQL编写,可以用于执行各种任务
语法
CREATE OR REPLACE FUNCTION function_name (parameter_list)
RETURN return_datatype
IS/AS-- 变量声明
BEGIN-- 函数体RETURN return_value;
EXCEPTIONWHEN OTHERS THEN--异常处理
END;
parameter_list 的格式 : 参数类型 参数1 数据类型; 参数类型 参数2 数据类型......
注意: oracle中自定义函数不需要declare
-
function_name:函数的名称,由用户自定义。常用函数名前缀: fun_
-
parameter_list:函数的参数列表,参数可以有
IN、OUT、IN OUT等模式。一般只用 in, 默认in -
return_datatype:函数返回值的数据类型。
-
IS/AS:开始函数体的关键字。
-
BEGIN ... END:函数的主体,包含执行的PL/SQL代码。

返回值
函数通过RETURN语句返回一个值。如果函数声明为返回某个数据类型,那么必须通过RETURN语句返回相应类型的值。
调用方式


自定义函数和存储过程的区别
1.自定义函数性能较差, 使用场景比存储过程少
2.自定义函数必须有返回值,存储过程没有,存储过程通过out参数向外传递数据
3.自定义函数的参数一般只使用in类型, 不使用out类型
4.自定义函数可以用一个值调用, 存储过程不可以
5.自定义函数在return处结束
6.自定义函数可以在sql中调用, 存储过程不可以
示例: 根据员工编号 获取姓名
CREATE OR REPLACE FUNCTION fun_get_ename(p_empno emp.empno%type)
RETURN varchar2
AS
v_ename varchar(30); --员工姓名
BEGINSELECT ename INTO v_ename FROM emp WHERE empno=p_empno;RAISE NOTICE 'v_ename:%', v_ename;RETURN v_ename;
EXCEPTIONWHEN OTHERS THENRAISE NOTICE '发生异常了';RAISE NOTICE 'SQLSTATE:%', SQLSTATE;RAISE NOTICE 'SQLERRM:%', SQLERRM;
END;
输出语句
oracle : DBMS_OUTPUT.PUT_LINE, 变量使用 和字符串使用 || 拼接, 注意单引号需要使用转义字符 '
高斯: RAISE NOTICE, 变量使用站位符%(示例是高斯输出)
函数调用示例
1.使用PLSQL调用
DECLAREv_name varchar(30);
BEGINv_name := fun_get_ename(7788);RAISE NOTICE '7788的姓名是:%', fun_get_ename(7788);
END;
2.在SQL中调用
SELECT emp.*, fun_get_ename(empno) FROM emp;
输出语句和return
-
输出语句的作用: 在函数执行过程中向客户端发送通知消息,这对于调试和日志记录非常有用。示例输出语句的作用是将变量
v_ename的值打印出来,以便调试和查看 -
RETURN用于返回函数的结果,是函数调用时返回给调用者的值。
return和out参数
return : 用于从函数中返回一个值。函数必须通过 RETURN 语句返回一个值,且返回值的数据类型在函数定义时指定

out 参数:用于从函数中返回额外的值。OUT 参数允许函数返回多个值
-
函数可以有多个
OUT参数。 -
只能在 PL/SQL 块中调用

示例

调用示例

IF v_status THEN 是合法的,因为 v_status 是一个布尔变量,IF 语句会根据它的值(TRUE 或 FALSE)来决定执行哪个分支
管理存储过程/自定义函数
修改存储过程/自定义函数
可以直接替换现有的存储过程/自定义函数

查看对象

查看源代码


删除存储过程/自定义函数
![]()
![]()

自定义函数也是
检查依赖关系(oracle)

USER_DEPENDENCIES 视图显示了当前用户下对象的依赖关系
检查其他用户的依赖关系,可以使用 ALL_DEPENDENCIES 视图(可以显示对象所有者: owner)
有DBA权限,可以使用 DBA_DEPENDENCIES 视图检查整个数据库中的依赖关系
使用时, 'UPDATE_VALUE'替换为需要检查依赖关系的对象名称
如果查询结果为空,说明没有其他对象依赖于该存储过程。
删除存储过程的权限
-
存储过程的所有者。
-
具有
DROP ANY PROCEDURE权限的用户。

如果返回结果不为空,这意味着当前用户具有删除任何用户创建的存储过程和函数的权限
DROP ANY PROCEDURE 权限主要与存储过程相关,但它也涵盖了对函数的删除权限。 因为在Oracle的权限体系中,函数(FUNCTION)和存储过程(PROCEDURE)在很多情况下被视为类似的对象,尤其是在权限管理方面。
相关文章:
PLSQL: 存储过程,用户自定义函数[oracle]
注意: raise notice是高斯的输出语句; DBMS_OUT_PUT.PUT_LINE是oracle的输出语句 存储过程 Stored Procedure 存储过程可以封装数据访问逻辑,使得应用程序可以通过调用存储过程来执行这些逻辑,而不是直接执行SQL语句。这有助于提高代码的可重用性、可…...
深度学习-医学影像诊断
以下以使用深度学习进行医学影像(如 X 光片)的肺炎诊断为例,为你展示基于 PyTorch 框架的代码实现。我们将构建一个简单的卷积神经网络(CNN)模型,使用公开的肺炎 X 光影像数据集进行训练和评估。 1. 安装必…...
备战蓝桥杯:双指针(滑动窗口)算法之逛花展
P1638 逛画展 - 洛谷 | 计算机科学教育新生态 这道题我们只要用一个kind和一个mp[N]的数组就能解决了 我们的解法1就是暴力枚举,先固定2,从2开始找连续的满足所有种类的最短的子数组,然后固定5,3,1,3&…...
Linux如何设置软件开机启动呢?
有很多软件,我们安装完之后,服务器一旦重启,软件也需要我们手动再次启动,有很多的软件我们不想手动重启,例如Redis、Mysql、MQ等,那我们怎么配置软件跟着服务器也一起启动呢,今天就给大家带来软…...
Vue(3)
一.生命周期及其四个阶段 Vue生命周期:一个Vue实例从创建到销毁的整个过程 生命周期四个阶段:①创建②挂载③更新④销毁 <body><div id"app"><h3>{{ title }}</h3><div><button click"count--"&…...
11vue3实战-----封装缓存工具
11vue3实战-----封装缓存工具 1.背景2.pinia的持久化思路3.以localStorage为例解决问题4.封装缓存工具 1.背景 在上一章节,实现登录功能时候,当账号密码正确,身份验证成功之后,把用户信息保存起来,是用的pinia。然而p…...
第16章 Single Thread Execution设计模式(Java高并发编程详解:多线程与系统设计)
简单来说, Single Thread Execution就是采用排他式的操作保证在同一时刻只能有一个线程访问共享资源。 1.机场过安检 1.1非线程安全 先模拟一个非线程安全的安检口类,旅客(线程)分别手持登机牌和身份证接受工作人员的检查,示例代码如所示。…...
MySQL 8.0.41 终端修改root密码
1.在 MySQL 命令行中,运行以下命令修改密码 ALTER USER rootlocalhost IDENTIFIED BY new_password; 其中,new_password替换为你想要设置的新密码 2.退出 MySQL终端,重新打开,使用新密码进入,修改成功...
微信小程序案例2——天气微信小程序(学会绑定数据)
文章目录 一、项目步骤1 创建一个weather项目2 进入index.wxml、index.js、index.wxss文件,清空所有内容,进入App.json,修改导航栏标题为“中国天气网”。3进入index.wxml,进行当天天气情况的界面布局,包括温度、最低温、最高温、天气情况、城市、星期、风行情况,代码如下…...
android的Compose 简介
Jetpack Compose 简介 Jetpack Compose 是 Android 官方推出的声明式 UI 工具包,用于替代传统 XML 布局,简化界面开发流程。它基于 Kotlin 语言,通过函数式编程实现高效、灵活的 UI 构建,支持实时预览和更直观的状态管理。 优势…...
缓存实战:Redis 与本地缓存
引言 在现代互联网应用中,缓存是提升系统性能和用户体验的关键技术之一。通过将频繁访问的数据存储在快速访问的存储介质中,可以显著减少对数据库的直接访问压力,从而提高系统的响应速度和吞吐量。 本文将从实战的角度出发,详细…...
apisix的real-ip插件使用说明
k8s集群入口一般都需要过负载均衡,然后再到apisix。 这时候如果后台业务需要获取客户端ip,可能拿到的是lb或者网关的内网ip。 这里一般要获取真实ip需要做几个处理。 1. 负载均衡上,一般支持配置获取真实ip参数,需要配置上。然…...
音视频协议
1. 多媒体信息 1.1 多媒体信息的两个主要特点: 信息量很大 标准语音:64Kbits(8KHz采样,8位编码)高质量音频:3Mbps(100KHz采样,12位编码) 在传输多媒体数据时,对时延和时延抖动均有较高要求 1.2 处理时延…...
第一财经对话东土科技 | 探索工业科技新边界
当前以ChatGPT、Sora等为代表的生成式人工智能快速发展,越来越多面向垂直场景的行业大模型涌现出来,并成为推动制造业智能化改造与数字化转型、加快推进新型工业化,进而培育发展新质生产力的新引擎。 在垂类场景的应用落地,是AI发…...
Maven 与企业项目的集成
1. Maven 在企业级项目中的作用 Maven 是 Java 生态中最流行的构建和依赖管理工具,广泛用于企业级项目的构建、依赖管理、测试、打包、部署和 CI/CD 集成。对于大型企业项目,Maven 提供了一整套标准化的构建流程,并支持 多模块(M…...
激活函数篇 01 —— 激活函数在神经网络的作用
欢迎来到我的主页:【Echo-Nie】 本篇文章收录于专栏【机器学习】 以下是激活函数系列的相关的所有内容: 激活函数篇 01 —— 一文搞懂激活函数在神经网络中的作用 逻辑回归:Sigmoid函数在分类问题中的应用 1 激活函数的作用 1.1 引入非线性 激活函数…...
22.2、Apache安全分析与增强
目录 Apache Web安全分析与增强 - Apache Web概述Apache Web安全分析与增强 - Apache Web安全威胁Apache Web安全机制Apache Web安全增强 Apache Web安全分析与增强 - Apache Web概述 阿帕奇是一个用于搭建WEB服务器的应用程序,它是开源的,它的配置文件…...
Day.23
leetcode 413.等差数列划分 问题:如果一个数列 至少有三个元素 ,并且任意两个相邻元素之差相同,则称该数列为等差数列。给你一个整数数组 nums ,返回数组 nums 中所有为等差数组的 子数组 个数。 子数组 是数组中的一个连续序列…...
CentOS虚机在线扩容系统盘数据盘
最近在制作Openstack下的镜像,用户需要CentOS6以及CentOS7的虚机镜像,遇到了些关于系统盘以及数据盘在线扩容的问题,故此整理一下。 传统我们想对磁盘在线热扩容,必然会想到LVM逻辑卷。如果没有LVM逻辑卷的情况下,…...
动手写ORM框架 - GeeORM第一天 database/sql 基础
文章目录 1 初识 SQLite2 database/sql 标准库3 实现一个简单的 log 库4 核心结构 Session本文是7天用Go从零实现ORM框架GeeORM的第一篇。介绍了 SQLite 的基础操作(连接数据库,创建表、增删记录等)。使用 Go 语言标准库 database/sql 连接并操作 SQLite 数据库,并简单封装…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战
“🤖手搓TuyaAI语音指令 😍秒变表情包大师,让萌系Otto机器人🔥玩出智能新花样!开整!” 🤖 Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制(TuyaAI…...
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
ABAP设计模式之---“简单设计原则(Simple Design)”
“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…...
重启Eureka集群中的节点,对已经注册的服务有什么影响
先看答案,如果正确地操作,重启Eureka集群中的节点,对已经注册的服务影响非常小,甚至可以做到无感知。 但如果操作不当,可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...
Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析
Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析 一、第一轮提问(基础概念问题) 1. 请解释Spring框架的核心容器是什么?它在Spring中起到什么作用? Spring框架的核心容器是IoC容器&#…...
AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别
【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而,传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案,能够实现大范围覆盖并远程采集数据。尽管具备这些优势…...
【安全篇】金刚不坏之身:整合 Spring Security + JWT 实现无状态认证与授权
摘要 本文是《Spring Boot 实战派》系列的第四篇。我们将直面所有 Web 应用都无法回避的核心问题:安全。文章将详细阐述认证(Authentication) 与授权(Authorization的核心概念,对比传统 Session-Cookie 与现代 JWT(JS…...
Qt Quick Controls模块功能及架构
Qt Quick Controls是Qt Quick的一个附加模块,提供了一套用于构建完整用户界面的UI控件。在Qt 6.0中,这个模块经历了重大重构和改进。 一、主要功能和特点 1. 架构重构 完全重写了底层架构,与Qt Quick更紧密集成 移除了对Qt Widgets的依赖&…...
HarmonyOS-ArkUI 自定义弹窗
自定义弹窗 自定义弹窗是界面开发中最为常用的一种弹窗写法。在自定义弹窗中, 布局样式完全由您决定,非常灵活。通常会被封装成工具类,以使得APP中所有弹窗具备相同的设计风格。 自定义弹窗具备的能力有 打开弹窗自定义布局,以…...
