在oracle中使用pl/sql来扩展SQL的功能,使得SQL能够更加的灵活,功能更加强大,效率更高。pl/sql让sql也能执行判断,循环等操作。主要记录一下pl/sql的基本语法和基本条件判断语句和循环语句供忘记了方便查阅。

1.pl/SQL的语法结构:

    declare

      //这部分用于声明变量

    begin

      //这部分用于处理业务逻辑

    exception

      //这部分用于处理例外也就是异常情况

    end;

   例如:   

      declare
        uname varchar2(10);
        hello varchar2(10) := 'helloworld'; --为变量赋值
        vsal emp.sal%type; --声明一个引用类型的变量
        pall emp%rowtype; --声明一个记录类型的变量
        digit number:=#---提示用户输入,然后根据用户输入执行相应的操作

        ...
      begin
        dbms_output.put_line(hello);
      exception
        when exception_name then

           //操作
      end;

2.)pl/sql的条件判断语句

    if 条件 then

      语句;

    elsif 条件then

      语句;

    else

      语句;

    end if;

例如:根据输入的年龄判断是处于哪个阶段的人

        declare
          age number := #
        begin
          if age < 18 then
             dbms_output.put_line('你还是未成年人');//表示系统输出语句,类似于system.out.print();
          elsif age > 18 and age <= 40 then
             dbms_output.put_line('你是青年人');
          else
             dbms_output.put_line('你是中年人!');
          end if;
        end;

3.)pl/sql的循环语句

  在pl/SQL中有三种循环结构。

  3.1)while 条件 loop

    语句块;

    end loop;

    例如:循环输出1-10的数。

      declare
        step number := 1;
      begin
        while step <= 10 loop
          dbms_output.put_line(step);
          step := step + 1;
        end loop;
      end;

  3.2)loop 循环语句

    loop

      exit when 退出条件;

      语句块;

    end loop;

例如:输出1-9的数。

      declare
        step number := 1;
      begin
        loop
          exit when step > 10;--当step>10退出循环
          dbms_output.put_line(step || ' ');
          step := step + 1;
        end loop;
      end;

  3.3)for语句循环结构

    for 循环变量 in n..N loop

      语句块;

    end loop;

例如:输出1-10之间的数。

    declare
    begin
      for step in 1.. 10 loop
      dbms_output.put_line(step);
    end loop;
    end;

案例1--使用PLSQL输出菱形
  declare
    m number := 10;
  begin
    for x in -m..m loop
      for y in -m..m loop
      if abs(y) + abs(x) <= m then
      dbms_output.put('*');
      else
      dbms_output.put(' ');
      end if;
      end loop;
    dbms_output.new_line();
   end loop;
  end;

案例2--使用PLSQL输出三角形。
  declare
    m number := 10;
  begin
    for x in reverse -m..m loop
      for y in -m..m loop
        if abs(y) + abs(x) <= m and x>=0 then
        dbms_output.put('*');
        else
        dbms_output.put(' ');
        end if;
      end loop;
    dbms_output.new_line();
    end loop;
  end;

以上就是pl/sql的基本语法以及基本的条件和循环结构。

oracle PL/SQL编程基础知识的更多相关文章

  1. Oracle Pl/SQL编程基础

    Pl/SQL简介 提高应用程序的运行性能, 提供模块化的程序设计, 自定义标示符, 具有过程语言控制结构, 良好的兼容性, 处理运行错误. Pl/SQL语言基础 sql是关系数据库的基本操作语言. s ...

  2. Oracle PL/SQL 编程基础 实例

    create table mytest(name varchar(20),password varchar(30)); create or replace procedure sp_pro2 is  ...

  3. Oracle数据库编程:PL/SQL编程基础

    2.PL/SQL编程基础: PL/SQL块:        declare        定义部分        begin        执行部分        exception        异 ...

  4. [推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)

    原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ...

  5. [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)

    原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下 ...

  6. [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)

    原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日 ...

  7. ORACLE PL/SQL编程详解

    ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...

  8. [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)

    原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...

  9. 【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航

    原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人 ...

随机推荐

  1. SQL 行转列(列的值不规则的数目)

    --创建一个临时表用来存储数据 create table #tmp_SNValue_Table (FieldName nvarchar(20), [Value] nvarchar(max)) inse ...

  2. CentOS7/RHEL7 pacemaker+corosync高可用集群搭建

     TOC \o "1-3" \h \z \u 一.集群信息... PAGEREF _Toc502099174 \h 4 08D0C9EA79F9BACE118C8200AA004B ...

  3. HDU3465--Life is a Line(树状数组求逆序数,离散化)

    Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Submission(s ...

  4. 【Django】搭建Django administration并登录

    Python自带一个后台管理系统,这个后台管理系统搭建与登陆呢? 新建项目Django_Admin 文件结构目录如下: 创建APP 在pycharm下方的terminal终端中输入命令: python ...

  5. [nginx] CORS配置多域名

    如下 server { listen 80; server_name www.your.com; root /data/web/www.your.com; access_log /var/log/ng ...

  6. spring boot redis session

    1. pom.xml 这里 spring parent的版本 2.1.5会报错 2.1.0和2.1.4经过测试正常 <?xml version="1.0" encoding= ...

  7. pytorch之Resize()函数

    Resize函数用于对PIL图像的预处理,它的包在: from torchvision.transforms import Compose, CenterCrop, ToTensor, Resize ...

  8. 【机器学习速成宝典】模型篇06决策树【ID3、C4.5、CART】(Python版)

    目录 什么是决策树(Decision Tree) 特征选择 使用ID3算法生成决策树 使用C4.5算法生成决策树 使用CART算法生成决策树 预剪枝和后剪枝 应用:遇到连续与缺失值怎么办? 多变量决策 ...

  9. jQuery中的闭包和js中的闭包总结

    关于闭包的知识总结下: 一.闭包 1.定义 闭包的关键是作用域,概念是:能有读取其他函数内部的函数 使用的场景有很多,最常见的是函数封装的时候,再就是在使用定时器的时候,会经常用到; //闭包:有参数 ...

  10. Spring 之 IOC ,DI 理论

    本文是依照极客学院java<Spring之IOC>章节学习的心得.随笔记录 浅谈IOC:(Inversion of Control, 控制反转) Spring 核心容器,贯穿始终.所谓IO ...