首页 >

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

数据库|Oracle

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

oracle,存储过程,变量赋值
数据库-Oracle
安卓小程序源码,vscode密码,glog ubuntu,tomcat插件、,utlog.sqlite,重置服务器ftp密码,组件插件,新生前端框架,python开源爬虫,php生成二维码图片,SeO杂化,android开源网站,愚人节整人的网页,精仿蘑菇街时尚淘宝客源码整套dede模板,手机页面显示滚动条,delphi 文档管理系统,微信小程序 京东购物lzw
oracle存储过程中赋值给变量办法有哪些
社工库查询源码整,用vscode打开一个项目,ubuntu安装 问号,tomcat热部署内存泄漏,爬虫怎么理解,php获取数组指定元素,上海seo排名优化哪里有lzw
Oracle存储过程 变量声明和赋值的方法
flappy bird 3d源码,vscode导出配置,ubuntu21.04网络配置,tomcat运行空间,sqlite负载有多大,分页插件 bootstrap,vue前端框架用什么启动,爬虫可以抢课吗,php 文字 水印,政和企业seo,网站部署 模板,html移动端网页模板下载工具,帝国模板安装lzw
1.声明变量的3种方式

按照数据类型的声明方式进行区分

方式一:直接声明数据类型

格式:变量名 数据类型(大小)

V_START_DATE VARCHAR2(19);v_num number;

说明:

设置为字符串类型时,需要指定大小,否则报错;

变量的声明必须在”begin”关键字之前进行。

--错误用法BEGINv_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_CARDSELECT * 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教学》


  • 暂无相关文章
  • Posted in 未分类