`
guiqing85
  • 浏览: 168844 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

PL/SQL学习笔记-循环控制与顺序控制(四)

SQL 
阅读更多
一:LOOP...END LOOP
先看代码

declare
v_flag number := 1;
begin
loop 
       exit when v_flag>16;
       v_flag := v_flag+1;
       dbms_output.put_line(to_char(v_flag));
end loop;
end;


其中exit when是跳出循环的条件,
注意代码中的分号,挺重要的。没有分号会报错

二:while……loop….end loop
几个和循环结构相关的代码,我比较喜欢这个,如下:

declare
v_flag number := 1;
begin
while v_flag<16 loop
       v_flag := v_flag+1;
       dbms_output.put_line(to_char(v_flag));
end loop;
end;


注意这个示例程序和上个示例程序的输出结果是不同的
具体为什么不同我就不多解释了

三:for…loop…end loop
还是类似的示例程序:
declare
v_flag number := 1;
begin
for v_flag in 2..16 loop
       --v_flag := v_flag+1;
       dbms_output.put_line(to_char(v_flag));
end loop;
end;



注意我用--注释掉了一句
因为在这个循环体内,是不允许为哨兵变量赋值的
哨兵变量不知道啥意思?hehe
--是注释单行的写法
/*  …..*/可以注释多行

四:顺序控制goto
看例子:

declare
v_flag number := 1;
begin
while v_flag<16 loop
       v_flag := v_flag+1;
       dbms_output.put_line(to_char(v_flag));
       if mod(v_flag,6) = 0 then
          goto lable_1;
       end if;
end loop;
<<lable_1>>
dbms_output.put_line('跳出来了');
end;


mod(v,n)是取余数的意思,
这里写这个函数其实没意义
还不如直接判断变量是否等六
另外需要注意的是goto语句有很多限制
以下都是不被允许的:
1跳转到非执行语句前面
2跳转到子块中
3跳转到条件语句中
4跳转到循环语句中
5从条件语句的一部分跳转到另一部分
6从异常处理部分跳转到执行部分

分享到:
评论

相关推荐

    Oracle PL/SQL专家指南-高级PL/SQL解决方案的设计与开发

    1. **PL/SQL基础**:涵盖PL/SQL的基本语法,包括变量声明、常量定义、条件语句(IF-THEN-ELSIF-ELSE)、循环结构(WHILE, FOR)、异常处理(BEGIN-EXCEPTION-END)以及子程序(PROCEDURE和FUNCTION)的创建与调用。...

    最容易上手的PL/SQL学习教程-有经过测试的丰富案例

    PL/SQL,全称Procedural Language/Structured Query Language,是Oracle数据库提供的一种过程化语言,它结合了SQL的查询功能和传统的编程语言特性,如变量、条件语句、循环结构等,使得数据库管理与应用开发更为灵活...

    pl/sql学习笔记

    2. **PL/SQL与Transact-SQL的比较** Transact-SQL(T-SQL)是Microsoft SQL Server使用的编程语言,与PL/SQL类似,但存在一些关键差异。T-SQL在语法上更接近标准SQL,而PL/SQL则提供了更丰富的过程编程特性。例如,...

    PL/SQL学习笔记

    PL/SQL支持多种流程控制语句,包括条件语句(如IF和CASE)以及循环语句(如FOR、WHILE和LOOP)。这些控制语句用于实现程序的逻辑判断和重复执行等控制结构。 在PL/SQL中使用SQL语句时,分为DML语句(如INSERT、...

    Oracle PL/SQL实例精讲--使用表,课后答案

    在"Oracle PL/SQL实例精讲--使用表,课后答案"中,读者可以深入理解如何有效地使用PL/SQL与Oracle数据库中的表格进行交互。这份资源包含第五版的课程内容,提供了实际操作的例子和课后练习的答案,对于学习者来说是...

    pl/SQL---Oracle帮助文档

    Oracle技术文档,Pl/SQl 的使用说明书

    oracle10g_pl/sql

    4. **PL/SQL与SQL的交互** - **嵌套SQL**:在PL/SQL代码中执行SQL查询,如SELECT INTO语句。 - **游标**:用于处理查询结果集,允许逐行访问数据。 5. **PL/SQL高级特性** - **记录类型**:自定义的数据结构,...

    Oracle PL/SQL程序设计(第5版)(上下册)

    - **集合与记录**:学习如何使用PL/SQL中的集合和记录类型,这些结构可以帮助更高效地处理数据集。 - **游标**:介绍游标的使用方法,包括隐式游标和显式游标,以及如何利用游标遍历查询结果。 #### 四、PL/SQL中的...

    Oracle-PL/SQL-windows-32位-客户端

    Oracle PL/SQL是Oracle数据库与开发人员之间交互的重要工具,特别是在Windows 32位系统上。这个压缩包“Oracle-PL/SQL-windows-32位-客户端”包含了Oracle数据库32位客户端所需的组件,主要用于在Windows环境下进行...

    pl/sql 学习资料

    2. **PL/SQL与SQL交互**: - DML操作:INSERT、UPDATE、DELETE语句在PL/SQL中的使用。 - SELECT INTO语句:从查询结果中提取数据到PL/SQL变量。 -游标:使用游标处理多行结果集,进行逐行操作。 3. **异常处理**...

    PL/SQL学习教程,附笔记

    而PL/SQL则是一种过程化语言,允许用户编写包含控制结构(如循环、条件判断)的程序块,以执行一系列SQL命令。PL/SQL的优势在于: 1. **错误处理**:提供了异常处理机制,能更好地控制程序流程。 2. **模块化编程**...

    Oracle PL SQL专家指南_高级PLSQL解决方案的设计与开发

    Oracle PL/SQL是Oracle数据库系统中的过程化语言,它结合了SQL的数据库操作能力和传统的编程语言特性,使得...通过学习,读者将能够设计和开发出高效、可靠的PL/SQL解决方案,提升在Oracle数据库系统中的编程能力。

    PL/SQL 基本知识

    首先,PL/SQL是一种过程化语言,它允许用户定义变量、控制流程(如循环、条件语句)、处理异常,并且可以嵌入SQL查询,进行数据的增删改查操作。通过使用PL/SQL,数据库管理员和开发者可以更高效地管理和维护数据库...

    oracle 9i pl/sql程序设计笔记

    通过上述对Oracle 9i PL/SQL程序设计笔记的总结,我们可以看到PL/SQL作为一种强大的数据库编程语言,提供了丰富的功能来支持数据处理、事务控制及业务逻辑的实现。掌握PL/SQL的不同块类型及其使用方法对于开发高效、...

    pl/sql最新中文手册

    11. **PL/SQL与Java、C等其他语言的互操作性**:Oracle提供了与多种编程语言接口的机制,手册会讲解如何在PL/SQL中调用外部程序或被其他程序调用。 12. **调试和错误诊断**:最后,手册会介绍如何使用Oracle提供的...

    PL/SQL学习资料

    PL/SQL,全称Procedural Language/Structured Query Language,是Oracle数据库的一种扩展,它将SQL的查询功能与过程式编程语言(如Pascal或C)的控制结构结合在一起,为数据库开发提供了一种强大的工具。这个“PL/...

    Oracle PL/SQL学习官方教材

    13. **PL/SQL与Java、.NET等其他平台的集成**:讲解如何使用Oracle的JDBC驱动或ODP.NET与PL/SQL交互,实现跨平台的应用程序开发。 14. **最佳实践**:教材可能还会提供编写高效、可读性强、易于维护的PL/SQL代码的...

    一个对数据库的操作工具PL/SQLpl/sqL工具

    1. **编程能力**:PL/SQL允许编写包含控制结构(如循环、条件语句)和异常处理的程序块,这些块可以存储在数据库中并按需调用,提高了数据库应用的灵活性和复杂性。 2. **数据处理**:通过PL/SQL,用户可以直接对...

    Oracle资料学习PL/SQL必备

    PL/SQL(Procedural Language/Structured Query Language)是Oracle专为数据库操作设计的一种过程化编程语言,结合了SQL的强大查询功能与高级编程语言的控制结构,使得数据库管理员和开发人员能够更高效、安全地管理...

Global site tag (gtag.js) - Google Analytics