oracle存储过程中赋值给变量的方法有哪些 |
您所在的位置:网站首页 › python执行过程打印 › oracle存储过程中赋值给变量的方法有哪些 |
赋值给变量的方法: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中文网其它相关文章! |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |