oracle PL/SQL编程基础知识

时间:2021-08-15 06:44:08

在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&sol;SQL编程基础

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

  2. Oracle PL&sol;SQL 编程基础 实例

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

  3. Oracle数据库编程:PL&sol;SQL编程基础

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

  4. &lbrack;推荐&rsqb;ORACLE PL&sol;SQL编程详解之三:PL&sol;SQL流程控制语句&lpar;不给规则,不成方圆&rpar;

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

  5. &lbrack;推荐&rsqb;ORACLE PL&sol;SQL编程详解之一:PL&sol;SQL 程序设计简介&lpar;千里之行,始于足下&rpar;

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

  6. &lbrack;顶&rsqb;ORACLE PL&sol;SQL编程详解之二:PL&sol;SQL块结构和组成元素&lpar;为山九仞,岂一日之功&rpar;

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

  7. ORACLE PL&sol;SQL编程详解

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

  8. &lbrack;强烈推荐&rsqb;ORACLE PL&sol;SQL编程详解之七:程序包的创建与应用&lpar;聪明在于学习,天才在于积累!&rpar;

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

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

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

随机推荐

  1. ArcGIS Engine开发之地图基本操作(4)

    ArcGIS Engine开发中数据库的加载 1.加载个人地理数据库数据 个人地理数据库(Personal Geodatabase)使用Miscrosoft Access文件(*.mdb)进行空间数据 ...

  2. ajaxSubmit

    $('button').on('click', function() {    $('form').on('submit', function() {        var title = $('in ...

  3. hdu 5284 BestCoder Round &num;48 &lpar;&dollar;&rpar; 1001 水题 &ast;

    题意:看一个字符串中是否包含顺序的  w  y  h ,字符之间可以有其他字符,并且如果有多个连续的vv,则可以看做一个w 比较水,直接看代码 #include<cstdio> #incl ...

  4. Android(java)学习笔记229:服务(service)之绑定服务调用服务里面的方法 (采用接口隐藏代码内部实现)

    1.接口 接口可以隐藏代码内部的细节,只暴露程序员想暴露的方法 2.利用上面的思想优化之前的案例:服务(service)之绑定服务调用服务里面的方法,如下: (1)这里MainActivity.jav ...

  5. 医院API免费接口的公布

    医院通网(http://hospital.yi18.net) 站点上站快两个月了,基本已经稳定,尽管还有非常多小bug,但还是不影响大局.抱着数据开放和共享的理念,医院大全API接口 (http:// ...

  6. docker 中国站 www&period;dockerpool&period;com 报价图片下载

    为了方便一些基本的下载docker 镜像,我建立了一个docker该站 http://www.dockerpool.com 对于Docker用户提供一站式Docker镜像服务: 稳定可靠的官方镜像下载 ...

  7. Visual Studio 2017 通过SSH 调试Linux 上&period;NET Core

    Visual Studio 2017 通过SSH 调试Linux 上.NET Core 应用程序. 本文环境 开发环境:Win10 x64 Visual Studio 2017 部署环境:Ubuntu ...

  8. usaco training 4&period;1&period;1 麦香牛块 题解

    Beef McNuggets题解 Hubert Chen Farmer Brown's cows are up in arms, having heard that McDonalds is cons ...

  9. 指数型生成函数 及 多项式求ln

    指数型生成函数 我们知道普通型生成函数解决的是组合问题,而指数型生成函数解决的是排列问题 对于数列\(\{a_n\}\),我们定义其指数型生成函数为 \[G(x) = a_0 + a_1x + a_2 ...

  10. 轻量级web富文本框——wangEditor使用手册(1)——基本应用 demo

    最新版wangEditor: 配置说明:http://www.wangeditor.com/doc.html demo演示:http://www.wangeditor.com/wangEditor/d ...