一、代码

/*1.定义存过*/
CREATE OR REPLACE
PROCEDURE PRO_RE_USER_ORD_GOODS(
--NOW_DATE格式:YYYYMMDD 如:20190801(此时统计的是2019年7月31日的数据)
NOW_DATE IN VARCHAR2
)
IS /*2.定义变量 START*/
--定义RECORD型记录类型;
TYPE T_RECORD IS RECORD (
GOODS_CODE VARCHAR2 (64),
GOODS_NAME VARCHAR2 (64)
) ;
--定义返回结果集接收的变量,类型为T_RECORD;
  PS:这里也可以不用record,直接指定V_ROWRESUT为%rowtype类型
V_ROWRESUT T_RECORD ;
--定义主键
PID VARCHAR2 (256) ;
/*2.定义变量 end*/ /*3.定义游标,执行查询结果集操作 START*/
CURSOR CUR_RE_USER_ORD_GOODS
IS
--查询语句开始
SELECT
A .GOODS_CODE,
B.GOODS_NAME
FROM
(
SELECT
ORD.GOODS_CODE
FROM
ORDER_INFO ORD
GROUP BY
ORD.GOODS_CODE
) A
LEFT JOIN GOODS_INFO B ON A .GOODS_CODE = B.GOODS_CODE ;
--查询语句结束
/*3.定义游标,执行查询结果集操作 END*/ /*4.打开并循环游标,进行数据操作 START*/
BEGIN
OPEN CUR_RE_USER_ORD_GOODS; --打开游标;
LOOP --开始执行循环,遍历查询结果集表;
FETCH CUR_RE_USER_ORD_GOODS INTO V_ROWRESUT; --循环游标并赋值给结构体变量;
EXIT WHEN CUR_RE_USER_ORD_GOODS %NOTFOUND; --如果游标遍历完成,就退出循环; --获取 UUID 并赋值给 PID 变量;
SELECT SYS_GUID() INTO PID FROM DUAL; --插入“订购商品记录表” 开始
INSERT INTO RE_USER_ORD_GOODS (
ID,
GOODS_CODE,
GOODS_NAME,
CREATE_TIME
)VALUES(
PID,
V_ROWRESUT.GOODS_CODE,
V_ROWRESUT.GOODS_NAME,
SYSDATE
);
--插入“订购商品记录表” 结束 END LOOP; --结束循环;
CLOSE CUR_RE_USER_ORD_GOODS; --关闭游标;
COMMIT; --提交 INSERT 操作;
END;
/*4.打开并循环游标,进行数据操作 END*/

oracle存储过程中is和as区别

  • 在存储过程(PROCEDURE)和函数(FUNCTION)中没有区别;
  • 在视图(VIEW)中只能用AS不能用IS;
  • 在游标(CURSOR)中只能用IS不能用AS。

声明变量的方式

  • v_temp     varchar(10)
  • v_temp     tablename.property%type(表名属性名%type,指的是一个表中某个字段的类型,这样可以灵活使用)
  • v_stu    student%rowtype;(这种类型就是定义一个变量,这个变量的类型为一个表数据的行类型,用于接收查询的一整行数据

赋值方式

  • :=

Oracle学习(九)存过、游标、RECORD整合的更多相关文章

  1. oracle学习 九 游标的使用(持续更)

    为什么要使用? 笔者查阅了一些资料之后得到的结论是, 关系型数据库是面向集合的,而游标是面向行的,游标可对取出来的集合(结果集)中每一行进行相同或不同的操作,还提供对基于游标位置而对表中数据进行删除或 ...

  2. Oracle学习(七)游标

    一.简介 定义 实质上是数据集,类似数组一样,把查询的数据集存储在内存当中. 使用时可以通过游标指向其中一条记录,也可以通过循环游标达到循环数据集的目的. 游标的种类 显式游标: 使用之前必须得先声明 ...

  3. oracle 学习(四)游标

    显式游标 隐式游标:如果在PL/SQL程序段中使用SELECT语句进行操作,PL/SQL 会隐含的处理游标定义,即为隐式游标.这种游标不需要像显式那样声明,也不必打开关闭. CREATE OR REP ...

  4. oracle学习--循环语句

    oracle学习--循环语句  loop循环: create or replace procedure pro_test_loop is i number; begin i:=0; loop i:=i ...

  5. oracle中表空间管理,游标

    一.表空间 oracle使用表空间来管理数据库的对象(表,序列,过程,函数,游标等). oracle的逻辑结构(看不见的):oracle数据库 => 表空间 => 表 序列  过程等对象. ...

  6. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  7. Oracle学习线路

    出自huyangg的博客,地址是:oracle学习路线图 1.sql.pl/sql(网上有很多的视频,可以做一个简单的入手,然后看几本书,多做实验)    作为oracle的基本功,需要大家对sql和 ...

  8. Oracle学习指南

    Oracle学习指南 你走的那天,我决定不落泪,迎着风撑着眼帘用力不眨眼 创建数据库.创建用户.创建表空间.创建表.插入数据..... 1.用系统用户登录,任选系统用户 代码: >>sql ...

  9. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

  10. Oracle学习系列7

    Oracle学习系列7 ************************************************************************************ 关联表 ...

随机推荐

  1. golang基础结构

    1.命名 Go语言中的函数名.变量名.常量名.类型名.语句标号和包名等所有的命名,都遵循一个简单的命名规则:一个名字必须以一个字母(Unicode字母)或下划线开头,后面可以跟任意数量的字母.数字或下 ...

  2. 第5篇scrum冲刺(5.25)

    一.站立会议 1.照片 2.工作安排 成员 昨天已完成的工作 今天的工作安排 困难 陈芝敏   线下模块(还剩下获取词的数据库)  研究云开发,更新了登录模块,把用户的信息传入数据库了  起初在云函数 ...

  3. MacOS开发环境搭建

    1 Java 安装jdk 下载安装即可,没什么可说的,着重说一下配置mac下的环境变量 $ /usr/libexec/java_home -V #查看安装的jdk版本和路径 $ vim ~/.bash ...

  4. 0基础掌握接口测试神器-Postman

    一:Postman环境搭建 1:postman是什么?Postman是一款功能强大的网页调试与发送网页HTTP请求的接口测试工具.2:postman有几种安装方式?两种,应用程序和浏览器插件 3:po ...

  5. 解决SpringBoot jar包中的文件读取问题

    前言 SpringBoot微服务已成为业界主流,从开发到部署都非常省时省力,但是最近小明开发时遇到一个问题:在代码中读取资源文件(比如word文档.导出模版等),本地开发时可以正常读取 ,但是,当我们 ...

  6. 模拟IIC总线多设备挂载(12864OLED屏幕+GY30光照传感器)

    最终效果展示 OLED屏幕和GY30光照传感器(BH1750FVI)都连接在一个IIC(I2C)总线上,所以只需要接4根线即可.获取到的光照强度可以在OLED上实时显示并通过串口打印.IIC是IO模拟 ...

  7. 神奇的BUG系列-01

    有时候遇见一个bug,感觉就是他了 其实他也不过是你职业生涯中写的千千万万个bug中的一员 你所要做的,是放下 日子还长,bug很多,不差这一个 就此别过,分手快乐 一辈子那么长,一天没放下键盘 你就 ...

  8. LWPR

    Scriptable Render Pipeline https://docs.unity3d.com/Manual/ScriptableRenderPipeline.html     Unity轻量 ...

  9. 分布式文件存储:FastDFS简单使用与原理分析

    引言 FastDFS 属于分布式存储范畴,分布式文件系统 FastDFS 非常适合中小型项目,在我接手维护公司图片服务的时候开始接触到它,本篇文章目的是总结一下 FastDFS 的知识点. 用了 2 ...

  10. SpringBoot系列之从入门到精通系列教程

    对应SpringBoot系列博客专栏,例子代码,本博客不定时更新 Spring框架:作为JavaEE框架领域的一款重要的开源框架,在企业应用开发中有着很重要的作用,同时Spring框架及其子框架很多, ...