oracle 包,函数,过程,块的创建和执行及在java中执行(转)

SQL> create or replace procedure sp_guocheng1 is--如果有这个名字就替换
  2  begin--执行部分
  3  insert into guocheng values(‘liyifeng‘,‘liyifeng‘);
  4  end;
  5  /  --执行的意思
 
Procedure created

显示错误
SQL> show error;
Errors for PROCEDURE LIYIFENG.SP_GUOCHENG1:
 
LINE/COL ERROR
-------- -----------------------------------------------------------------------------------------------------------------------------------------------------------------------

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

--------------------------------------
3/22     PL/SQL: ORA-00928: 缺失 SELECT 关键字
3/1      PL/SQL: SQL Statement ignored
6/0      PLS-00103: 出现符号 "end-of-file"在需要下列之一时:   ( begin case     declare end exception exit for goto if loop mod null pragma     raise return select update while

with <an identifier>     <a double-quoted delimited-identifier> <a bind variable> <<     continue close current delete fetch lock insert open rollback     savepoint set sql

execute commit forall merge pipe purge

执行过程

SQL> exec sp_guocheng1;
 
PL/SQL procedure successfully completed
 
SQL> commit;

一个新的快
SQL> set serveroutput on;--打开输出选项
SQL>
SQL> begin
  2    dbms_output.put_line(‘hello,world‘);--dbms_output是包.put_line是过程
  3  end;
  4  /
 
hello,world
 
PL/SQL procedure successfully completed

带有变量的查询
SQL> declare
  2  v_ename varchar2(25);
  3  v_id number;
  4  begin
  5    select name,id into v_ename,v_id from stu where name=&aa;
  6    dbms_output.put_line(‘用户名是:‘||v_ename||v_id );
  7  end;
  8  /
 
用户名是:liyifeng            0
 
PL/SQL procedure successfully completed

带有类外的查询
SQL> declare
  2  v_ename varchar2(25);
  3  v_id number;
  4  begin
  5    select name,id into v_ename,v_id from stu where name=&aa;
  6    dbms_output.put_line(‘用户名是:‘||v_ename||v_id );
  7  exception
  8    when no_data_found then
  9      dbms_output.put_line(‘您输入的数据不存在!‘);
 10  end;
 11  /
 
您输入的数据不存在!
 
PL/SQL procedure successfully completed

--传入参数的过程  注意,定义参数的时候不能带上长度。
create procedure sp_gc1(v_id number,v_name varchar2) is
begin
  update stu set name=v_name where id=v_id;
end;

过程在java中运行。。注意jdbc_oracle架包。。
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;

public class testExec {

/**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub

Connection ct=null;
  try{
   //加载驱动
//  Class.forName("com.hxtt.sql.access.AccessDriver");//连接access的
  Class.forName("oracle.jdbc.driver.OracleDriver");
  //创建连接
  ct=DriverManager.getConnection("jdbc:oracle:thin:@192.168.1.9:1521:orcl","liyifeng","liyifeng");
  //创建 callablestatement
  CallableStatement cs=ct.prepareCall("{call sp_gc1(?,?)}");
  //给?复制
  cs.setInt(1, 0);
  cs.setString(2, "mountLee");
  //设置不自动提交事务
  ct.setAutoCommit(false);
  
  cs.execute();
  
  //提交事务
  ct.commit();
  //关闭资源
  cs.close();
  ct.close();
  }
  catch (Exception e){
   try {
   //如果失败,就回滚
   ct.rollback();
   }
   catch(Exception ex){ex.printStackTrace();}
   
   e.printStackTrace();
  }
 }

}

--传入参数并有返回值的函数
create or replace function sp_guoc(v_id number) 
return varchar2 is v_name varchar2(20);
begin
  select name into v_name from stu where id=v_id;
return v_name;
end;

java中调用函数

Statement sm=ct.createStatement();
  ResultSet rs=sm.executeQuery("select sp_guoc(0) from stu");
  if(rs.next()){
  System.out.print(rs.getString(1));}

--创建包
create or replace package sp_pack is
procedure sp_pd (v_id number,v_name varchar2);
function  sp_ft (v_id number) return number;
end;

--创建包体
create or replace package body sp_pack is
procedure sp_pd(v_id number,v_name varchar2) is
begin
  update stu set name=v_name where id=v_id;
end;
function sp_ft(v_id number)
return number is v_name number;
begin
  select id into v_name from stu where id=v_id;
return v_name;
end;
end;

执行包中的过程

SQL> exec sp_pack.sp_pd(0,‘lee‘);
 
PL/SQL procedure successfully completed
 
SQL> commit;
 
Commit complete

java中执行包中函数的方法。

Statement sm=ct.createStatement();
  ResultSet rs=sm.executeQuery("select sp_pack.sp_ft(0) from stu");
  if(rs.next()){
  System.out.print(rs.getString(1));}

http://blog.163.com/mount_lee/blog/static/20202509520122292827986/

时间: 2024-11-05 23:58:38

oracle 包,函数,过程,块的创建和执行及在java中执行(转)的相关文章

Java中执行存储过程和函数(web基础学习笔记十四)

一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. CallableStatement 接口继承自PreparedStatement 接口.所以CallableStatement 接口包含有Statement 接口和PreparedStatement 接口定义的全部方法,但是并不是所有的方法我们都要使用,主要使用的方法有这样几个: CallableStatement 常用方法: 返回类型 方法签名 说明 boolean execute() 执行 SQL 语句

Java中this和static关键字及代码块

this: 可以使用this表示类中的属性------this.name=name 可以使用this强调调用的是本类的方法 可以使用this调用本类的构造方法------this();调用本类中无参构造方法 可以使用this表示当前对象(调用方法的对象)----最重要的用途 static: 声明属性---------属性则为全局变量 声明方法---------Person.setName("Tom");使用类名称调用static方法 普通代码块:直接在方法或是语句中定义的代码块 pub

oracle PL/SQL(procedure language/SQL)程序设计之函数+过程+包(转)

匿名PL/SQL块回顾 DECLARE (可选)     定义在PL/SQL块中要使用的对象 BEGIN (必须)     执行语句 EXCEPTION (可选)     错误处理语句 END; (必须) 匿名块(以DECLARE或BEGIN开始)每次使用时都要进行编译. 匿名块不存储在数据库中,并且它不能从其它的PL/SQL块中进行调用. 过程.函数.包和触发器:都是带名块.(请注重同匿名块的比较) 过程.函数.包和触发器:可以存储在数据库中,并且可以在需要的时候运行. 过程.函数.包和触发器

Oracle中函数/过程返回多个值(结果集)

Oracle中函数/过程返回结果集的几种方式: 以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过. (1) 返回游标: return的类型为:SYS_REFCURSOR 之后在IS里面定义变量:curr SYS_REFCURSOR; 最后在函数体中写:          open cur for             select ......;          return cur; 例: CREATE OR REPLACE FUNCTION A_Te

oracle包的创建

一 包的组成 1)包头(package):包头部分申明包内数据类型,常量,变量,游标,子程序和异常错误处理, 这些元素为包的公有元素. 2)包主体(package body):包主体则是包定义部分的具体实现,它负责为包头中所声明子程序 提供具体的实现,在包主体中还可以声明包的私有元素 3)包头和包主体分开编译,并作为两个分开的对象分别存放在数据库字典中 --删除package --drop package pkg_lxg_test; --1)首先创建package头(头和body的sql不要写在

oracle包详解(二)【weber出品】

一.重载子程序 PL/SQL中的重载功能: 1. 能够使用户创建两个或多个同名的子程序 2. 要求子程序的形式参数的数量,顺序或者数据类型不一样 3. 能够使用户使用不同的数据灵活的调用子程序 4. 对已经存在的代码的功能的扩展 注意: 重载可以对本地子程序,包,包中的子程序,方法进行重载,不能对标准的子程序进行重载 示例:先创建表和序列 conn scott/tiger drop table d purge; create table d as select * from dept where

Oracle 包(package)

1.包 包是一组相关过程.函数.变量.常量#SinaEditor_Temp_FontName.类型和游标等PL/SQL程序设计元素的组合.包具有面向对象设计的特点,是对这些PL/SQL程序设计元素的封装.一个包由两个分开的部分组成: (1)包package声明或定义:包定义部分是创建包的规范说明,声明包内数据类型.变量.常量.游标等元素.这部分也是为使用者提供了透明的接口. (2)包体packpage body:包体是包定义部分的具体实现. (3)将有联系的对象打成包,方便使用 (4)包中对象包

Oracle——包

包用于在逻辑上组合过程和函数,它由包规范和包体两个部分组成.(1)首先用CREATE PACKAGE创建包规范,只包含过程和函数的说明,但没有过程和函数的实现代码 --创建一个包名称为sp_package--声明该包含有一个过程update_sal--声明该包含有一个函数annual_incomeCREATE OR REPLACE PACKAGE sp_package ISPROCEDURE update_sal(spname VARCHAR2, sal NUMBER);FUNCTION  an

oracle包概述(一)【weber出品】

一.PL/SQL包概述 1. 什么是PL/SQL包: 相关组件的组合:PL/SQL类型.变量,数据结构,和表达式.子程序: 过程和函数 2. 包的组成部分: 由两部分组成: 包头 包体 3. 包的优点 一次读取多个对象进入内存 二.PL/SQL包的组件 包头:公共部分:包内和包外的程序都可以访问 包体:私有部分:包体定义的变量或者程序只能被本包内的程序调用 1. 创建包头 语法: CREATE [OR REPLACE] PACKAGE package_name IS|AS public type