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

简介: SQL> create or replace procedure sp_guocheng1 is--如果有这个名字就替换  2  begin--执行部分  3  insert into guocheng values('liyifeng','liyifeng');  4  end;  5  /...

 

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;

 

 

 

【原创】oracle 块的创建和执行,存储过程的创建及在java中执行 - Mount_Lee - Mount_Lee的博客

 

 

 

 

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/

 

相关文章
|
1月前
|
Java 数据安全/隐私保护
JAVA包
JAVA包
12 0
|
1月前
|
JavaScript 前端开发 Java
Java Script中的函数原型是什么
Java Script中的函数原型是什么
11 0
|
14天前
|
Java Maven
【Java报错】显示错误“Error:java: 程序包org.springframework.boot不存在“
【Java报错】显示错误“Error:java: 程序包org.springframework.boot不存在“
35 3
|
6天前
|
Oracle 算法 关系型数据库
Oracle常用系统函数之数字类函数:数字的魔术师
【4月更文挑战第19天】Oracle数据库中的数字类函数是数字处理的魔术师,包括`ROUND`(四舍五入),`CEIL`和`FLOOR`(向上/下取整),以及`ABS`(计算绝对值)。还有`MOD`、`TRUNC`和`POWER`等函数,提供求余数、截断和计算幂的功能。熟练运用这些函数能提升数据管理效率,让处理数字变得更简单、有趣。
|
1月前
|
Java 数据库连接 API
Java 学习路线:基础知识、数据类型、条件语句、函数、循环、异常处理、数据结构、面向对象编程、包、文件和 API
Java 是一种广泛使用的、面向对象的编程语言,始于1995年,以其跨平台性、安全性和可靠性著称,应用于从移动设备到数据中心的各种场景。基础概念包括变量(如局部、实例和静态变量)、数据类型(原始和非原始)、条件语句(if、else、switch等)、函数、循环、异常处理、数据结构(如数组、链表)和面向对象编程(类、接口、继承等)。深入学习还包括包、内存管理、集合框架、序列化、网络套接字、泛型、流、JVM、垃圾回收和线程。构建工具如Gradle、Maven和Ant简化了开发流程,Web框架如Spring和Spring Boot支持Web应用开发。ORM工具如JPA、Hibernate处理对象与数
93 3
|
1月前
|
Java
Java包及访问限定
Java包及访问限定
8 0
|
1月前
|
Java 数据安全/隐私保护
Java的包机制
Java的包机制
26 8
Java的包机制
|
1月前
|
Java 编译器 Go
25、Java 初始化块和静态初始化块详解,超详细(案例多、官方教程)
25、Java 初始化块和静态初始化块详解,超详细(案例多、官方教程)
72 1
|
2月前
|
存储 Oracle Java
Java 包和 API 深度解析:组织代码,避免命名冲突
Java 中的包 用于将相关的类分组在一起。可以将其视为文件目录中的一个文件夹。我们使用包来避免名称冲突,并编写更易于维护的代码。 包分为两类: 内置包(来自 Java API 的包) 用户定义的包(创建自己的包)
309 2
|
2月前
|
存储 Java API
Java基础篇----包机制与JavaDoc
Java基础篇----包机制与JavaDoc
27 3

推荐镜像

更多