• 技术文章 >数据库 >Oracle

    oracle存储过程中赋值给变量的方法有哪些

    青灯夜游青灯夜游2022-01-25 16:57:38原创182

    赋值给变量的方法:1、使用“:=”直接赋值,语法“变量名:=值;”;2、使用“select 表字段 into 变量 from 表”语句;3、使用“execute immediate sql语句字符串 into 变量”语句。

    本教程操作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

    Oracle存储过程 变量声明和赋值的方法

    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);  

    推荐教程:《Oracle教程

    以上就是oracle存储过程中赋值给变量的方法有哪些的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:oracle怎样查询死锁 下一篇:oracle分页查询原理是什么

    相关文章推荐

    • 怎样关闭oracle数据库• oracle触发器的写法是什么• oracle的转义字符是什么• 怎样执行oracle存储过程• oracle怎样修改字符集• oracle怎样递归查询子节点

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网