Oracle入门(十四.4)之在PL / SQL中使用变量

一、变量的使用

(1)使用变量的原因

•临时存储数据
•储存值的操作
•可重用性


(2)处理PL / SQL中的变量

变量是:
•在声明部分声明并初始化
•在可执行部分中使用并分配新值
变量可以是:
•作为参数传递给PL / SQL子程序
•分配以保存PL / SQL子程序的输出

(3)声明变量

在PL / SQL块中引用所有PL / SQL变量之前,必须在声明部分声明它们。
•声明的目的是为值分配存储空间,指定其数据类型并命名存储位置以便引用它。

•您可以在任何PL / SQL块,子程序或包的声明部分声明变量。

语法

identifier [CONSTANT] datatype [NOT NULL] [:= expr | DEFAULT expr];

(4)初始化变量

变量在DECLARE部分中分配一个内存位置。 变量可以同时分配一个值。 这个过程称为初始化。

DECLARE
v_counter INTEGER := 0;
BEGINv_counter := v_counter + 1;DBMS_OUTPUT.PUT_LINE(v_counter);
END; 

(5)声明和初始化变量示例1

DECLAREfam_birthdateDATE;fam_size NUMBER(2) NOT NULL := 10;fam_location VARCHAR2(13) := 'Florida';fam_bank CONSTANT NUMBER := 50000;fam_population INTEGER;fam_name VARCHAR2(20) DEFAULT 'Roberts';fam_party_size CONSTANT PLS_INTEGER := 20;

(6)声明和初始化变量示例2

DECLAREv_emp_hiredate DATE;v_emp_deptno NUMBER(2) NOT NULL := 10;v_location VARCHAR2(13) := 'Atlanta';c_comm CONSTANT NUMBER := 1400;v_population INTEGER;v_book_type VARCHAR2(20) DEFAULT 'fiction';v_artist_nameVARCHAR2(50);v_firstname VARCHAR2(20):='Rajiv';v_lastname VARCHAR2(20) DEFAULT 'Kumar';c_display_no CONSTANT PLS_INTEGER := 20;
…

二、在可执行部分中分配值

声明变量后,可以在PL / SQL块的可执行部分中使用它。 例如,在下面的块中,变量v_myname在块的声明部分中声明。 您可以在同一个块的可执行部分访问此变量。 你认为这个块会打印什么?

DECLAREv_myname VARCHAR2(20);
BEGINDBMS_OUTPUT.PUT_LINE('My name is: '||v_myname);v_myname := 'John';DBMS_OUTPUT.PUT_LINE('My name is: '||v_myname);
END;

(1)在可执行部分中分配值

例1
在这个例子中,值John被分配给可执行部分中的变量。 该变量的值与串 My name is:。
输出是:

My name is:
My name is: John

Statement process.

例2

在此块中,变量v_myname在声明部分中声明并初始化。 初始化后,v_myname保存值John。 该值在块的可执行部分中进行处理。

DECLAREv_myname VARCHAR2(20):= 'John';
BEGINv_myname := 'Steven';DBMS_OUTPUT.PUT_LINE('My name is: '||v_myname);
END; 

输出是:

My name is: Steven
Statement processed.

(2)将变量作为参数传递给PL / SQL子程序

参数是由用户或另一个程序传递给程序以定制程序的值。 在PL / SQL中,子程序可以带参数。 您可以将变量作为参数传递给过程和函数。 在以下示例中,参数v_date正被传递给过程PUT_LINE,该过程是包DBMS_OUTPUT的一部分。

DECLAREv_date VARCHAR2(30);
BEGINSELECT TO_CHAR(SYSDATE) INTO v_date FROM dual;DBMS_OUTPUT.PUT_LINE(v_date);
END;

(3)分配变量到PL / SQL子程序输出

您可以使用变量来保存函数返回的值。

--function to return number of characters in string
FUNCTION num_characters (p_string IN VARCHAR2) RETURN INTEGER ISv_num_characters INTEGER;
BEGINSELECT LENGTH(p_string) INTO v_num_characters FROM dual;RETURN v_num_characters;
END;
--anonymous block: assign variable to function output
DECLAREv_length_of_string INTEGER;
BEGINv_length_of_string := num_characters('Oracle Corporation');DBMS_OUTPUT.PUT_LINE(v_length_of_string);
END;


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/329370.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

dismiss的词组_法律英语常用词必记:Dismiss

Dismiss英[dɪsmɪs] 美[dɪsmɪs]【英文释义】v.to refuse to give further hearing to a case in court. If a judge dismisses a court case, they officially decide that the case should not continue【中文释义】v. (1)解雇;免职;开除(2)驳回(起诉…

构建高性能.NET应用之配高可用IIS服务器-第五篇 IIS常见问题之:工作进程回收机制(中)

我们在本篇中接着讲述“工作进程回收机制”。 本篇文章的议题如下: 工作进程回收机制讲解 基于时间的回收机制 基于请求数的回收机制 基于内存使用的回收机制 基于活动状态的回收机制 基于请求数的回收机制 这种基于请求数量回收的机制非常的好理解:当我…

10.netty客户端与服务器使用protobuf传输报文

【README】 本文总结自B站《尚硅谷-netty》,很不错; 内容如下: netty的编码器与解码器;netty客户端与服务器通过 protobuf 传输报文的开发方式;文末po出了所有代码;【1】netty的编码器与解码器 codec 1&…

Oracle入门(十四.5)之识别数据类型

一、PL / SQL数据类型 数据类型指定存储格式,约束和有效的值范围。 PL / SQL支持五类数据类型:二、标量数据类型(Scalar) (1)标量数据类型•保持一个值 •没有内部组件 •可以分为四类: - 性格…

TFS2015的CI集成

这篇应该是这个系列的最后一篇了 配置生成代理 配置dotnet cli环境 这步,需要在生成代理的机器上配置cli环境,与本地配置方法一致,可以自行Google 下载及参考地址: https://www.microsoft.com/net/core#windows 配置环境变量 在生…

pivot sqlserver 条件_行转列之SQLSERVERPIVOT与用法详解

在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某店铺的一周收入情况表:WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL)我们先插入一些模拟数据:INSERT INTO WEEK_INCOMESELECT 星期一,1000UNION ALLSE…

Oracle入门(十四.6)之使用标量数据类型

一、声明字符变量 字符数据类型包括CHAR,VARCHAR2和LONG。 DECLAREv_emp_job VARCHAR2(9);v_order_no VARCHAR2(6);v_product_id VARCHAR2(10);v_rpt_body_part LONG; …二、声明数字变量 数字数据类型包括NUMBER,PLS_INTEGER,BINARY_INTEGER…

11.netty入站与出站(处理器链调用机制)

【README】 1.本文源代码总结自 B站《netty-尚硅谷》;2.本文部分内容总结自 https://www.baeldung.com/netty3.本文主要介绍了通道管道中多个入栈处理器与多个出站处理器如何执行?并用代码演示执行顺序; 补充:文末附带了 log4j整…

1688推广工具_全面了解1688数字营销

全面了解1688数字营销什么是数字营销?在数字营销中,有一款很重要的工具-一键推广。在我们的日常经营和大促中,通过一键站外推广可以在各大站外平台实现全店、各产品的推广,尤其在大促中,结合活动当天的站内流量&#x…

Entity Framework升级

第三篇是Entity Framework升级 修改project.json 把原来 EntityFramework 的包 换成 Microsoft.EntityFrameworkCore 版本从 7.0.0-rc1-final 改为 1.0.0-rc2-final 对照表如下: RC1 PackageRC2 EquivalentEntityFramework.MicrosoftSqlServer 7.0.0-rc1-finalMicro…

12.netty中tcp粘包拆包问题及解决方法

【README】 1.本文源代码总结自B站《netty-尚硅谷》;2.本文介绍了tcp粘包拆包问题;3.本文po 出了粘包拆包问题解决方案及源代码实现;【1】tcp粘包拆包问题 refer2 How to deal with the problem of packet sticking and unpacking during T…

Oracle入门(十四.7)之良好的编程习惯

一、目的良好的编程实践是可以遵循的技术来创建最佳代码。 编程实践涵盖了从编写更易读的代码到创建具有更快性能的代码。软件工程团队通常会遵循风格指南,以便团队中的每个人都使用相同的技术。 这使得读取和修改其他人编写的代码变得更加容易。二、编程实践您已经…

css 浏览器调试中不可见_前端入门必会的初级调试技巧

本文仅仅针对前端初学者,目的是【用20%不到的时间】 学会【前端最常用的部分调试技巧】,如果需要最详细的调试技巧,包括调试性能优化的相关知识,文末会补充最全的文档(chrome devtool的官方文档链接)初学一…

升级ASP.Net Core项目

升级完类库项目,第二篇,我们来升级ASP.Net Core项目 修改global.json与project.json 这里可以参照,升级.Net Core RC2的那些事(一) 这里补充一点就是如果你觉得这样修改复杂,你完全可以新建一个项目&#x…

gophp解释器_【干货】Gisp 解释器 Golang 辅助开发工具

Gisp 是一个提供给 golang 使用的 Lisp 类 DSL 解释器。在 Lisp 的基本语法基础上,针对 go 环境稍作了一点语法糖。主要目标是提供一个尽可能便于与 golang 互操作的微型DSL工具。简介Gisp用go语言编写,是一个DSL 解释器,这个 DSL 基本上就是…

Oracle入门(十四.8)之迭代控制:基本循环Loop

一、迭代控制:LOOP语句 循环多次重复一个语句或一系列语句。 PL / SQL提供了以下几种类型的循环:•没有全面条件执行重复操作的基本循环 •FOR循环,基于计数器执行迭代操作•WHILE循环根据条件执行重复操作二、基本循环LOOP语句的最简单形式…

phpst安装memcache扩展_在 Ubuntu/Debian 下安装 PHP7.3 教程

介绍最近的 PHP 7.3.0 已经在 2018 年12月6日 发布 GA,大家已经可以开始第一时间体验新版本了,这里先放出 PHP7.3 安装的教程以便大家升级。适用系统: Ubuntu 18.04 LTS / Ubuntu 16.04 LTS / Ubuntu 14.04 LTS / Debian 9 stretc…

升级.Net Core RC1的类库项目

微软终于发布了.Net Code RC2了,作为一个软粉当然是第一时间升级了。《升级.Net Core RC2的那些事》系列文章主要是记录本人升级RC2的相关步骤以及遇到过的坑。 第一篇先写类库项目(Nuget包项目)的升级 升级VS工具 这里只提供一个下载地址&am…

Oracle入门(十四.9)之迭代控制:WHILE和FOR循环

一、WHILE循环您可以使用WHILE循环重复一系列语句,直到控制条件不再为TRUE。 条件在每次迭代开始时进行评估。当条件为FALSE或NULL时,循环终止。 如果条件在循环开始时为FALSE或NULL,则不会执行进一步的迭代。 WHILE condition LOOPstatement…

为TFS配置跨平台的生成服务器Xplat (Ubuntu Linux)

1. 概述 从TFS 2015开始,微软开始支持跨平台的构建代理。你可以使用TFS的Xplat代理,方便的在基于IOS, Unix和Linux的服务器上搭建生成代理,实现构建、发布等功能。本文档已Ubuntu为例,指导如何安装和运行Xplat代理。 2. 配置TFS的…