SQLserver和ORACLE存储过程

SQLserver:

ALTER PROCEDURE [dbo].[dp_p_GetSaleData_test]@sss AS nvarchar //传入参数,这个参数未被使用
AS
BEGIN-- routine body goes here, e.g.-- SELECT 'Navicat for SQL Server'select convert(decimal(19,0),isnull(SM.sumShipQty-RCV.sumRcvQty,0)) as sumQty_year  from (select sum(a.ShipQtyTUAmount) as sumShipQty from sm_shipline as a inner join sm_ship as b on a.ship = b.idinner join SM_ShipDocType as c on c.id = b.DocumentTypeinner join base_organization as d on d.id = b.orgwhere d.code = '506' and c.code = 'SMZ'   and  b.Status = 3  )SMleft join(select isnull(sum(a.RcvQtySU),0) as sumRcvQty from PM_RcvLine as a inner join PM_Receivement as b on a.receivement = b.IDinner join PM_RcvDocType as c on c.ID = b.RcvDocTypeinner join base_organization as d on d.ID = b.orgwhere d.Code = '506' and c.code = 'RCC'   and b.Status = 5  ) as RCV on 1=1END

调用:

exec [dbo].[dp_p_GetSaleData_test] 'd'  --参数未被使用,所随便传

oracle:

CREATE OR REPLACE procedure testprocedure
(
--定义输入、输出参数--
-- num_A in integer,
-- num_B in integer,
-- numType in integer,
-- num_C out integer
namecc in VARCHAR)as
--定义变量---- numCount integer;-- numStr varchar(20); 
v_addr varchar2(2000);
begin   --判断计算类型--
--      if numType=1 then
--         num_C := num_A + num_B;
--      elsif numType=2 then
--         num_C := num_A - num_B;
--      elsif numType=3 then
--         num_C := num_A * num_B; 
--      elsif numType=4 then
--         num_C := num_A / num_B; 
--      else
--      --其它处理
--        dbms_output.put_line('其它处理');
--      end if;
--      dbms_output.put_line(num_C);SELECT CLIENT_NAME INTO v_addr from LK_REPAIR_ORDER  WHERE CLIENT_NAME = namecc AND ROWNUM <2;dbms_output.put_line(v_addr);end;

调用:

call TESTPROCEDURE('陈xx');

模版二:

CREATE OR REPLACE PROCEDURE my_procedure AS-- 声明游标变量CURSOR my_cursor ISSELECT column1, column2, column3FROM my_table;-- 声明游标结果集的类型TYPE my_cursor_type IS REF CURSOR;-- 声明游标变量my_result my_cursor_type;-- 声明变量用于接收查询结果my_column1 my_table.column1%TYPE;my_column2 my_table.column2%TYPE;my_column3 my_table.column3%TYPE;BEGIN-- 打开游标OPEN my_cursor;-- 将游标赋给游标变量my_result := my_cursor;-- 循环遍历游标结果集LOOP-- 从游标变量中获取下一行数据FETCH my_result INTO my_column1, my_column2, my_column3;-- 判断是否还有数据EXIT WHEN my_result%NOTFOUND;-- 在这里可以对查询结果进行处理或输出DBMS_OUTPUT.PUT_LINE('Column1: ' || my_column1 || ', Column2: ' || my_column2 || ', Column3: ' || my_column3);END LOOP;-- 关闭游标CLOSE my_cursor;END;
/

例子:

CREATE OR REPLACE PROCEDURE get_orgnameuserid_by_code (p_code IN orgnameuserid.code%TYPE,p_result OUT SYS_REFCURSOR
) ASv_code orgnameuserid.code%TYPE;v_name orgnameuserid.ORGANIZATION_NAME%TYPE;
BEGINOPEN p_result FORSELECT code, ORGANIZATION_NAMEFROM orgnameuseridWHERE code = p_code;LOOPFETCH p_result INTO v_code, v_name;EXIT WHEN p_result%NOTFOUND;-- 这里可以对获取的数据进行处理-- 可以输出、存储或使用数据DBMS_OUTPUT.PUT_LINE('Code: ' || v_code || ', Organization Name: ' || v_name);END LOOP;CLOSE p_result;
END;

调用:

DECLAREv_result SYS_REFCURSOR;
BEGINget_orgnameuserid_by_code('502', v_result);
END;

例子二:

CREATE OR REPLACE procedure update_orgname_userid AS
BEGIN
DECLAREmy_data  VARCHAR2(4000);
BEGINfor cur in (SELECT a.code,a.name,--使用 XMLAGG 和 XMLPARSE 函数来执行字符串连接:RTRIM(XMLAGG(XMLELEMENT(E, au.login_name || ',')).EXTRACT('//text()').getclobval(), ',') AS login_name
FROM app_user au
LEFT JOIN BASE_ORGANIZATION a ON au.organization_id = a.id
WHERE au.organization_id is not nulland au.organization_id <> 'NULL'and au.channel_customer_id is nulland au.dr = 0
GROUP BY a.name,a.code)loop UPDATE orgnameuseridSET login_name = cur.login_name,organization_name = cur.nameWHERE code = cur.code;IF cur.name = 'xxx控股有限公司' THENmy_data := '123456';ELSESELECT RTRIM(XMLAGG(XMLELEMENT(E, au.login_name || ',')).EXTRACT('//text()').getclobval(), ',')INTO my_dataFROM app_user auLEFT JOIN BASE_ORGANIZATION a ON au.organization_id = a.idWHERE au.organization_id IS NOT NULLAND au.organization_id <> 'NULL'AND au.channel_customer_id IS NULLAND au.dr = 0AND a.name = 'xxx控股有限公司'GROUP BY a.name, a.code;END IF;UPDATE orgnameuseridSET login_name = cur.login_name || ',001002,' || my_data,organization_name = cur.nameWHERE code = cur.code;-- 打印更新消息DBMS_OUTPUT.PUT_LINE('Updated login_name for organization: ' || cur.name);end loop;END;END;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/149536.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

最新绿豆影视系统 /反编译版源码/PC+WAP+APP端 /附搭建教程+软件

源码简介&#xff1a; 最新的绿豆影视系统5.1.8&#xff0c;这可是个反编译版的源码哦&#xff01;它不仅支持PC端、WAP端&#xff0c;还有APP端&#xff0c;一应俱全。而且附上了搭建教程和软件&#xff0c;安卓和苹果双端都能用&#xff0c;实用方便&#xff01; 优化内容&…

力扣647-回文子串(Java详细题解)

题目链接&#xff1a;力扣647-回文子串 前情提要&#xff1a; 因为本人最近都来刷dp类的题目所以该题就默认用dp方法来做。 dp五部曲。 1.确定dp数组和i下标的含义。 2.确定递推公式。 3.dp初始化。 4.确定dp的遍历顺序。 5.如果没有ac打印dp数组 利于debug。 每一个d…

软考高级:中台相关知识 AI 解读

中台&#xff08;Middle Platform&#xff09;是近年来在软件开发和企业架构中兴起的一种理念和架构模式&#xff0c;尤其在中国的互联网企业中得到了广泛应用。中台的核心思想是通过构建一个共享的服务和能力平台&#xff0c;支持前端业务的快速迭代和创新&#xff0c;从而提升…

【学习笔记】TLS/SSL握手之Records

TLS / SSL会话是由记录&#xff08;Records&#xff09;所组成&#xff0c;有4种records HandshakeAlertChange Cipher SpecApplication DataHandshake和Alert Records被分为子类型&#xff08;Subtypes&#xff09;&#xff1a; Handshake&#xff1a;Client HelloHandshake&a…

塑料瓶回收标志分级检测系统源码分享

塑料瓶回收标志分级检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Co…

QT编译之后的debug包下运行程序双击运行出现无法定位程序输入点__gxx_personlity_seh0于动态链接库

1.出现这个错误的原因是&#xff1a; 缺少如下文件&#xff1a; 2.解决方法&#xff1a; 在运行程序.exe所在的目录执行&#xff1a;windeployqt untitled.exe&#xff08;指打包的运行程序&#xff09; 3.如果执行提示由于找不到qt5core.dll,无法继续执行代码和无法识别win…

第十一章 从0-1搭建一个简单的JavaWeb系统(三)

目录 一、工程代码结构 二、代码实现 三、运行效果 四、未完待续 本章节的每一段代码&#xff0c;建议全部自己敲一遍&#xff0c;加深印象&#xff0c;切勿直接复制黏贴。 一、工程代码结构 本章节实现注销&#xff08;退出&#xff09;功能&#xff0c;以下图片中标红的…

无线感知会议系列【4】【基于WiFi和4G/5G的非接触无线感知:挑战、理论和应用-2】

前言&#xff1a; 本篇重点分享一下该论文 《Human Respiration Detection with Commodity Wifi Devices: Do User Location and Body Orientation Matter》 接 2020年北京智源大会 张大庆老师的一个报告 参考&#xff1a; https://blog.csdn.net/chengxf2/article/detai…

[Unity Demo]从零开始制作空洞骑士Hollow Knight第十集:制作后坐力系统Recoil和小骑士的生命系统和受伤系统

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、制作后坐力系统Recoil 1.使用代码实现扩展新的后坐力行为2.为敌人脚本添加后坐力行为3.为小骑士添加后坐力行为二、制作小骑士的生命系统和受伤系统 1.制作…

sqlserver 合并重复行数据,取有值的字段

我有这样的一个需求&#xff0c;先看数据 上面的记录&#xff0c;圈起来的 数据关键字段是重复的&#xff0c;但有的字段不一样&#xff0c; 我现在想合并为一条&#xff0c;特殊字段&#xff0c;取有值的 搜了很多行转列&#xff0c;都不是我需要的 不过有了启发&#xff0…

【自动驾驶】基于车辆几何模型的横向控制算法 | Pure Pursuit 纯跟踪算法详解与编程实现

写在前面&#xff1a; &#x1f31f; 欢迎光临 清流君 的博客小天地&#xff0c;这里是我分享技术与心得的温馨角落。&#x1f4dd; 个人主页&#xff1a;清流君_CSDN博客&#xff0c;期待与您一同探索 移动机器人 领域的无限可能。 &#x1f50d; 本文系 清流君 原创之作&…

从零开始学习Python

目录 从零开始学习Python 引言 环境搭建 安装Python解释器 选择IDE 基础语法 注释 变量和数据类型 变量命名规则 数据类型 运算符 算术运算符 比较运算符 逻辑运算符 输入和输出 控制流 条件语句 循环语句 for循环 while循环 循环控制语句 函数和模块 定…

一文学会 Java 8 的Predicates

​ 博客主页: 南来_北往 系列专栏&#xff1a;Spring Boot实战 前言 在这份详细的指南中&#xff0c;您将了解 Java Predicates&#xff0c;这是 Java 8 中一个新颖且有用的特性。本文解释了 Java Predicates 是什么以及如何在各种情况下使用它们。 在这份详尽的指南中…

JVM 几种经典的垃圾收集器

目录 前言 Serial Serial Old ParNew Parallel Scavenge Parallel Old CMS收集器 garbage first 收集器 前言 回顾一下之前的几种垃圾收集算法: JVM java主流的追踪式垃圾收集器-CSDN博客文章浏览阅读646次&#xff0c;点赞22次&#xff0c;收藏16次。简要介绍了几…

AI大模型教程 Prompt提示词工程 AI原生应用开发零基础入门到实战【2024超细超全,建议收藏】

在AGI&#xff08;通用人工智能&#xff09;时代&#xff0c;那些既精通AI技术、又具备编程能力和业务洞察力的复合型人才将成为最宝贵的资源。为此&#xff0c;我们提出了‘AI全栈工程师’这一概念&#xff0c;旨在更精准地描述这一复合型人才群体&#xff0c;而非过分夸大其词…

RocketMQ消费者消费的时候,宕机了,消息会丢失吗?

一个消息从生产者产生&#xff0c;到被消费者消费&#xff0c;主要经过这3个过程&#xff1a; 因此,本文将从以下这几个维度来回答: 生产者如何保证不丢消息 存储端如何保证不丢消息 消费者如何保证不丢消息 最后消费者消费的时候,宕机,消息会不会丢呢? 1. 生产者如何保证…

SaaS 软件转型计划

目录 一、转型目标 1、背景与趋势分析 2、转型策略与实施路径 3、预期成果与展望 二、现状分析 1、产品评估&#xff1a;从传统到SaaS的华丽转身 2、客户群体洞察&#xff1a;倾听需求&#xff0c;引领变革 3、销售渠道优化&#xff1a;拓宽路径&#xff0c;触达更多客…

如何高效绘制ER图?

在数据驱动的时代&#xff0c;实体-关系图&#xff08;ER图&#xff09;作为数据建模的核心工具&#xff0c;对于理解、设计和优化数据库结构至关重要。然而&#xff0c;传统的手绘或复杂软件绘制ER图方式往往效率低下且难以协作。幸运的是&#xff0c;ProcessOn在线绘图工具以…

潮玩宇宙大逃杀宝石游戏搭建开发

潮玩宇宙大逃杀的开发主要涉及以下方面&#xff1a; 1. 游戏概念和设计&#xff1a; 核心概念定义&#xff1a;确定以潮玩为主题的宇宙背景、游戏的基本规则和目标。例如&#xff0c;玩家在宇宙场景中参与大逃杀竞技&#xff0c;目标是成为最后存活的玩家。 玩法模式设计&a…

飞睿智能实时雷达活体探测传感器模块,智能家居静止检测实时感知人员有无

随着科技的飞速发展&#xff0c;我们的生活正在经历着未有的创新。在这个创新的浪潮中&#xff0c;实时雷达活体探测传感器模块的技术正逐渐崭露头角&#xff0c;以其独特的优势为我们的生活带来安全与便捷。今天&#xff0c;我们就来详细探讨一下这项技术&#xff0c;看看它是…