首页数据库Oracle存储过程里变量赋值的方法有哪些

Oracle存储过程里变量赋值的方法有哪些

时间2024-03-22 15:08:03发布访客分类数据库浏览609
导读:这篇文章给大家分享的是“Oracle存储过程里变量赋值的方法有哪些”,文中的讲解内容简单清晰,对大家认识和了解都有一定的帮助,对此感兴趣的朋友,接下来就跟随小编一起了解一下“Oracle存储过程里变量赋值的方法有哪些”吧。 赋值给变量的方...
这篇文章给大家分享的是“Oracle存储过程里变量赋值的方法有哪些”,文中的讲解内容简单清晰,对大家认识和了解都有一定的帮助,对此感兴趣的朋友,接下来就跟随小编一起了解一下“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存储过程里变量赋值的方法有哪些”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注网络,小编每天都会为大家更新不同的知识。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Oracle存储过程里变量赋值的方法有哪些
本文地址: https://pptw.com/jishu/650661.html
oracle数据库中如何查询锁表,方法是什么 PHP中实现去除字符串里小数点的函数有什么

游客 回复需填写必要信息