Oracle入门(十四.3)之创建PL / SQL块

一、PL / SQL块结构

一个PL / SQL块由三部分组成。


PL / SQL块结构部分



二、PL / SQL编译器

    用高级编程语言(C,Java,PL / SQL等)编写的每个程序都必须经过检查并转换为二进制代码(1和0),然后才能执行。 执行此检查和翻译的软件称为编译器。


    PL / SQL编译器在需要时自动执行。 它不仅检查每个单词拼写是否正确,而且还检查是否存在任何引用的数据库对象(如表),并且用户具有访问它们的必要特权。


三、匿名块

(1)匿名块的特征
•未命名的块
•未存储在数据库中
•在其执行的应用程序中的内部声明为内联
•每次执行应用程序时编译
•传递给PL / SQL引擎以在运行时执行

•无法调用或调用,因为它没有名称,执行后不存在

[DECLARE]
BEGIN--statements
[EXCEPTION]
END;
(2)匿名块的例子

没有声明或异常部分,只执行

BEGINDBMS_OUTPUT.PUT_LINE('PL/SQL is easy!');
END;

宣言和执行部分,但没有例外部分

DECLAREv_date DATE := SYSDATE;
BEGINDBMS_OUTPUT.PUT_LINE(v_date);
END;

宣言和例外部分

DECLAREv_country_name VARCHAR2(40);v_region_id NUMBER;
BEGINSELECT country_name, region_idINTO v_country_name, v_region_idFROM countries WHERE country_id='CA';DBMS_OUTPUT.PUT_LINE ('The country name is: '||v_country_name||' and is located in '||v_region_id||'.') ;
EXCEPTIONWHEN TOO_MANY_ROWS THENDBMS_OUTPUT.PUT_LINE ('Your select statement retrieved multiple rows. Consider using a cursor.');
END;


四、子程序

(1)子程序
•命名为PL / SQL块
•存储在数据库中

•可以根据您的应用程序随时调用

•可以声明为程序或功能
- 过程:执行操作
- 功能:计算并返回一个值

PROCEDURE name
IS--variable declaration(s)
BEGIN--statements
[EXCEPTION]
END;
FUNCTION name
RETURN datatype--variable declaration(s)
IS
BEGIN--statementsRETURN value;
[EXCEPTION]
END;
(2)子程序的例子

打印当前日期的过程

CREATE PROCEDURE print_date ISv_date VARCHAR2(30);
BEGINSELECT TO_CHAR(SYSDATE,'Mon DD, YYYY')INTO v_dateFROM DUAL;DBMS_OUTPUT.PUT_LINE(v_date);
END;

函数返回字符串中的字符数

CREATE PROCEDURE print_date ISv_date VARCHAR2(30);
BEGINSELECT TO_CHAR(SYSDATE,'Mon DD, YYYY')INTO v_dateFROM DUAL;DBMS_OUTPUT.PUT_LINE(v_date);
END;
CREATE FUNCTION num_characters (p_string IN VARCHAR2)RETURN INTEGER ISv_num_characters INTEGER;
BEGINSELECT LENGTH(p_string) INTO v_num_charactersFROM DUAL;RETURN v_num_characters;
END;


五、程序构造

下表概述了使用基本PL / SQL块的各种不同的PL / SQL程序结构。 这些构造是基于它们被执行的环境而提供的。



六、PL / SQL编程环境

有许多工具为环境提供了一个环境开发PL / SQL。 Oracle提供了几种工具可以使用。 一些Oracle开发工具是:



七、Oracle Application Express

Oracle Application Express是一个基于浏览器的Web应用程序环境,它提供了SQL Workshop组件。



八、使用SQL Workshop进行开发

当您登录到Oracle Application Express并选择SQL Workshop时,可以选择使用SQL命令选项来使用SQL命令行编辑器,也可以选择SQL脚本选项在脚本编辑器中工作。



九、SQL命令

您可以使用SQL命令输入并运行单个SQL语句或单个PL / SQL块。 SQL脚本可以包含一个或多个SQL语句和/或PL / SQL块。 使用SQL脚本输入并运行多语句脚本。



使用DBMS_OUTPUT.PUT_LINE示例
看看这个简单的PL / SQL块和它的输出。 你如何显示结果?



使用DBMS_OUTPUT.PUT_LINE

让我们添加一个对DBMS_OUTPUT.PUT_LINE的调用。 现在你可以看到结果!



DBMS_OUTPUT.PUT_LINE允许您显示结果,以便您可以检查您的块是否正常工作。 它允许您一次显示一个字符串,但可以将它们连接起来。

DECLAREv_emp_count NUMBER;
BEGINDBMS_OUTPUT.PUT_LINE('PL/SQL is easy so far!');SELECT COUNT(*) INTO v_emp_count FROM employees;DBMS_OUTPUT.PUT_LINE('There are '||v_emp_count||'rows in the employees table');
END;


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

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

相关文章

[.NET Core].NET Core R2安装及示例教程

前言 前几天.NET Core发布了.NET Core 1.0.1 R2 预览版,之前想着有时间尝试下.NET Core。由于各种原因,就没有初试。刚好,前几天看到.NET Core发布新版本了,决定要去一探究竟。于是乎,就立马去官网查找相关的信息&…

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

一、变量的使用 (1)使用变量的原因•临时存储数据 •储存值的操作 •可重用性(2)处理PL / SQL中的变量变量是: •在声明部分声明并初始化 •在可执行部分中使用并分配新值 变量可以是: •作为参数传递给PL …

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…