oracle数据库的随堂笔记(三)-过程、函数、触发器

oracle数据库的随堂笔记(三)-过程、函数、触发器

1.过程
  过程用于执行特定的操作。当建立过程时,既可以指定输入参数(in),也可以指定输出参数(out)。通过在过程中使用输入参数,可以将数据传递到执行部分;通过使用输出参数,可以将执行部分的数据传递到应用环境。在sqlplus中可以使用create procedure命令来建立过程
  实例如下:
    1)请考虑编写一个过程,可以输入雇员名,新工资来修改雇员的工资
    2)调用过程的两种方法
    3)如何在java程序中调用一个存储过程
  案例1:
    create procedure xf_pro1(sfName varchar2,newSal number) is
    –这里可以定义变量
    begin
    –执行部分,根据用户名去修改工资
    update emp set sal=newSal where ename=xfName;
    end;
    /

  调用方法:
    exec 过程名(参数)
    call 过程名(参数)

  在java程序中调用存储过程

    TestOraclePro.java
    //演示java程序调用oracle的存储过程案例
    package com.xf;
    import java.sql.*;
    public class TestOraclePro{

    public static void main(String[] args){

      try{

        //1.加载驱动
        Class.forName(“oracle.jdbc.driver.OracleDriver”);
        //2.得到连接
        Connection ct=DriverManager.getConnection(“jdbc:oracle:thin:@127.0.0.1:1521:MYORA1″,”scott”,”1234″);
        //3.创建CallableStatement
        CallableStatement cs=st.prepareCall(“{call xf_pro1{?,?}”);
        //4.给?赋值
        cs.setString(1,”SMITH”);
        sc.setInt(2,20);
        //5.执行
        cs.execute();
        //6.关闭
        cs.close();
        st.close();
      }catch(Exception e){

        e.printStackTrace();
      }
    }
   }

  ?如何使用过程返回值

2.函数
  函数用于返回特定的数据,当建立函数时,在函数头部必须包含return子句,而在函数体内必须包含return语句返回的数据。我们可以使用create function来建立函数
  实例如下:
    –输入雇员的姓名,返回该雇员的年薪
    create function xf_fun1(xfName varchar2) return
    number is yearSal number;
    begin
    –执行部分
    select sal*12+nvl(comm,0) into yearSal from emp where ename=xfName;
    return yearSal;
    end;
    /

  在sqlplus中调用函数
    sql>var income number;
    sql>call xf_fun1(‘SCOTT’) into:income;
    sql>print income;
  在java程序中调用函数
    select xf_fun1(‘SCOTT’) from dual;
    通过rs.getInt(1)得到返回的结果

3.包
  包用于在逻辑上组合过程和函数,它由包规范和包体两部分组成。
    1)我们可以使用create package命令来创建包:
    实例:
      –创建一个包xf_package,声明了一个过程update_sal和一个函数annual_income
      create package xf_package is
      procedure update_sal(name varchar2,newsal number);
      function annual_income(name varchar2) return number;
      end;
  包的规范只包含了过程和函数的说明,但是没有过程和函数的实现代码。包体用于实现包规范中的过程和函数
    2)建立包体可以使用create package body命令
      –给包xf_package实现包体
      create package body xf_package is
      procedure update_sal(name varchar2,newsal number) is
      begin
      update emp set sal=newsal where ename=name;
      end;
      function annual_income(name varchar2) return
      number is annualSal number;
      begin
      select sal*12+nvl(comm,0) into annualSal from emp where ename=name;
      return annualSal;
      end;
      end;
  如何调用包的过程或函数
    当调用包的过程或函数时,在过程和函数前需要带有包名,如果要访问其它方案的包,还需要在包名前加方案名。
      例:sql>call xf_package.update_sal(‘SCOTT’,1500);
        或sql>exec xf_package.update_sal(‘SCOTT’,1500);

4.触发器
  触发器是指隐含的执行的存储过程。当定义触发器时,必须要制定触发的事件和触发后的操作,常用的触发事件包括insert,update,delete语句,而触发操作实际上就是一个pl/sql块。

  可以使用create trigger来建立触发器

转载于:https://www.cnblogs.com/fei-er-blog/p/4162965.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/109624.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 免费国内php空间_全球vps交流网站超级vps管理器

    免费国内php空间_全球vps交流网站超级vps管理器网站名称:000webhost.com250MB硬盘空间,100GB数据流量有足够的空间存放你的网站,emails 和数据库. 服务器为百兆独享接入Internet, 所以可以提供100G的数据流量.PHP 和MySQL 数据库支持不想其他免费空间,对php和mysql的功能进行限制.在这里你可以使用最新版本的php和mysql. 所有以下php特性都支持:

  • Android listView中的button点击事件[通俗易懂]

    Android listView中的button点击事件[通俗易懂]Android–listView中的button控件获取item的值在listview中的listitem设置事件响应,如果listitem中有button控件,这时候listitem就不会捕获到点击事件,而默认的是listitem中的button会捕获点击事件,这方面的介绍网上很多,我想大家应该很熟悉了,之前做项目开发的时候遇到了一个问题,就是如果我点击listitem中的button怎么才能这个button是在哪一个item中呢,换句话说,就是点击listitem中的button怎么获取该list

  • python中for循环的用法-Python for循环及基础用法详解

    python中for循环的用法-Python for循环及基础用法详解Python中的循环语句有2种,分别是while循环和for循环,前面章节已经对while做了详细的讲解,本节给大家介绍for循环,它常用于遍历字符串、列表、元组、字典、集合等序列类型,逐个获取序列中的各个元素。for循环的语法格式如下:for迭代变量in字符串|列表|元组|字典|集合:代码块格式中,迭代变量用于存放从序列类型变量中读取出来的元素,所以一般不会在循环中…

  • linux服务器配置jdk环境变量

    因为Java项目部署需要Java运行环境jdk,要在Linux服务器上部署Java项目,就必须线安装好jdk并配置好环境变量;本篇文章记录了如何安装jdk以及配置环境变量。1.下载jdk2.使用sftp工具将下载的jdk文件上传到Linux服务器上3.将jdk文件移动到/usr/local/java路径下mvjdk-8u171-linux-x64.tar.gz…

  • JS中鼠标拖拽div(2)(setCapture()方法和releaseCapture()方法)

    JS中鼠标拖拽div(2)(setCapture()方法和releaseCapture()方法)接着鼠标拖拽div(1)解决问题,当在拖拽事件所在的页面按下键盘的ctrl+A全选后,再去拖拽div,浏览器会默认去搜索网页中的内容,拖拽功能就会失效,(搜索网页内容是浏览器的默认行为,所以要想不发生这种情况,就得将其取消,是谁执行之后触发了浏览器的默认行为,就在谁里面returnfalse即可取消浏览器的默认行为,但这种方式ie8及以下的版本不支持。)在ie8及以下版本浏览器中,如果调用了元素的setCapture()方法,那么点击任何事物都会来执行这个元素绑定的响应函数。例如:btn.oncl

  • c语言oj平台作业,OJ平台C语言习题答案.pdf

    c语言oj平台作业,OJ平台C语言习题答案.pdfOJ平台C语言习题答案return0;}★★★★★★★★★★用指针编写一个程序,输入字符串后,统计其中各种字符的个数,输出其中大小编写一个函数,功能是使输入的字符串逆序输出。…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号