oracle 存储过程 变量的声明和赋值的3种方式
2018-08-31 19:05
246 查看
oracle 存储过程 变量的声明和赋值的3种方式
CreationTime--2018年8月31日16点00分
Author:Marydon
1.声明变量的3种方式
按照数据类型的声明方式进行区分
方式一:直接声明数据类型
格式:变量名 数据类型(大小)
V_START_DATE VARCHAR2(19); v_num number;
说明:
设置为字符串类型时,需要指定大小,否则报错;
变量的声明必须在"begin"关键字之前进行。
--错误用法 BEGIN v_sql varchar2(100) := 'SELECT ORGSEQ FROM BASE_ORG_INFO where orgcode=to_char(410621101233)';
方式二:使用%TYPE声明
格式:变量名 表名.字段名%TYPE
含义:该变量的数据类型与指定表的指定字段的数据类型一致
V_ORGSEQ BASE_ORG_INFO.ORGSEQ%TYPE;
方式三:使用%ROWTYPE声明
格式:变量名 表名%ROWTYPE
含义:该变量的数据类型与指定表的指定行记录(所有字段)的数据类型一致
--VIRTUAL_CARD表整行数据 V_ROW_VIRTUAL_CARD VIRTUAL_CARD%ROWTYPE;
小结:
在存储过程中,声明变量时,不需要使用关键字"DECLARE";
变量不区分大小写;
变量在使用前必须声明。
2.变量赋值的3种方式
方式一:直接赋值,使用":="
使用条件:适用于声明变量的前2种方式。
V_ORGID := '110';
说明:
变量后面跟不能直接是sql语句,sql不会执行,可以参考方式三。
--错误用法 V_ORGSEQ := SELECT ORGSEQ INTO V_ORGSEQ FROM BASE_ORG_INFO; --正确用法 V_ORGSEQ := 'SELECT ORGSEQ INTO V_ORGSEQ FROM BASE_ORG_INFO';
变量的声明和赋值可以一块进行。
--正确用法 v_sql varchar2(100) := 'SELECT ORGSEQ FROM BASE_ORG_INFO where orgcode=to_char(410621101233)'; BEGIN /* 具体业务 */ END;
方式二:select 表字段 into 变量 from 表
变形一:查询指定表的一个指定字段
使用条件:适用于声明变量的前2种方式可以使用
--根据医疗机构ID查询对应的父机构的机构序列 SELECT ORGSEQ INTO V_ORGSEQ FROM BASE_ORG_INFO WHERE ORGID = (SELECT PARENTORGID FROM BASE_ORG_INFO WHERE ORGID = V_ORGID);
变形二:查询指定表的所有字段
使用条件:只适用于声明变量的第3种方式
--将id=5120的VIRTUAL_CARD表数据赋值给变量V_ROW_VIRTUAL_CARD SELECT * INTO V_ROW_VIRTUAL_CARD FROM VIRTUAL_CARD T where t.id = 5120;
说明:
查询结果只能返回一条记录;
查询的表字段必须是该表的所有字段。
错误举例:
--错误举例一:查询的是所有表记录 SELECT * INTO V_ROW_VIRTUAL_CARD FROM VIRTUAL_CARD T; --错误举例二:查询的是该表的多个字段 SELECT t.id,t.name INTO V_ROW_VIRTUAL_CARD FROM VIRTUAL_CARD T;
方式三:execute immediate sql语句字符串 into 变量
declare/* 存储过程,不需要声明 */ v_sql varchar2(100); V_ORGSEQ varchar2(100); begin v_sql := 'SELECT ORGSEQ FROM BASE_ORG_INFO where orgcode=to_char(410621101233)'; --V_ORGSEQ赋值 execute immediate v_sql INTO V_ORGSEQ; --打印结果 DBMS_OUTPUT.put_line(V_ORGSEQ); END;
3.变量的调用
一般来说,变量只有这3种使用场景:赋值、逻辑判断、算术运算;
说明:不能用作查询列
--错误调用 select V_ORGSEQ from dual;
使用%ROWTYPE声明的变量如何调用?
利用"变量名.表字段"的方式可以取到该表中指定行(返回行)的指定列(任意列)所代表的数据。
--V_ROW_VIRTUAL_CARD赋值 SELECT * INTO V_ROW_VIRTUAL_CARD FROM VIRTUAL_CARD T where t.id = 5120; --调用 DBMS_OUTPUT.put_line(V_ROW_VIRTUAL_CARD.ID);
相关推荐:
相关文章推荐
- php——学习笔记,变量声明以及3种赋值方式
- Oracle中PL/SQL语句的变量、常量声明和赋值
- oracle 存储过程中date类型变量声明中to_date赋值丢失时分秒问题
- oracle 变量声明 初始化 赋值
- SqlServer中存储过程中将Exec的执行结果赋值给变量输出
- 【转载】在Angular 2/Typescript中声明全局变量的最佳方式是什么?
- ES6--变量的声明及解构赋值
- IOS,objective_C中用@interface和 @property 方式声明变量的区别
- 大数据Java-交换变量的3种方式
- OC -- @interface和@property两种声明变量方式的区别
- SQL中声明变量并赋值
- 基于JavaScript 声明全局变量的三种方式详解
- hibernate里使用jdbc方式调用oracle带游标返回参数的简单分页存储过程
- javascript中var let const三种变量声明方式
- Thinking in java第四版--第2章习题答案--关键字、变量、声明、赋值、初始化、类型转换
- Oracle如何解决日期格式“01-3月 -18”的显示问题(3种处理方式)
- IOS,objective_C中用@interface和 @property 方式声明变量的区别
- Oracle12C--变量的声明与赋值(二十五)
- C++ 3维数组指针声明的3种方式
- 变量声明及赋值