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并发编程高阶技能:深入剖析无锁CAS机制、揭秘魔法类Unsafe、精通原子包Atomic,打造高效并发应用
【8月更文挑战第4天】在Java并发编程中,无锁编程以高性能和低延迟应对高并发挑战。核心在于无锁CAS(Compare-And-Swap)机制,它基于硬件支持,确保原子性更新;Unsafe类提供底层内存操作,实现CAS;原子包java.util.concurrent.atomic封装了CAS操作,简化并发编程。通过`AtomicInteger`示例,展现了线程安全的自增操作,突显了这些技术在构建高效并发程序中的关键作用。
55 1
|
20天前
|
Java Maven 数据库
Java 包(package)
Java 包(package)
22 1
|
20天前
|
Java 调度 Android开发
Android经典实战之Kotlin的delay函数和Java中的Thread.sleep有什么不同?
本文介绍了 Kotlin 中的 `delay` 函数与 Java 中 `Thread.sleep` 方法的区别。两者均可暂停代码执行,但 `delay` 适用于协程,非阻塞且高效;`Thread.sleep` 则阻塞当前线程。理解这些差异有助于提高程序效率与可读性。
39 1
|
22天前
|
Java
Java应用结构规范问题之在biz层的convert包实现转换的问题如何解决
Java应用结构规范问题之在biz层的convert包实现转换的问题如何解决
|
1月前
|
Java
Java 基础语法-面试题(54-63道)(数组+类+包)
Java 基础语法-面试题(54-63道)(数组+类+包)
35 16
|
19天前
|
存储 运维 Java
函数计算产品使用问题之怎么配置定时触发器来调用Java函数
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
21天前
|
开发框架 Java Android开发
JNI中调用Java函数
JNI中调用Java函数
13 0
|
22天前
|
开发框架 Java Android开发
JNI中调用Java函数
JNI中调用Java函数
22 0
|
27天前
|
JavaScript Java API
Java日志通关(二) - Slf4j+Logback 整合及排包
作者日常在与其他同学合作时,经常发现不合理的日志配置以及五花八门的日志记录方式,后续作者打算在团队内做一次Java日志的分享,本文是整理出的系列文章第二篇。
|
2月前
|
存储 Java Unix
(八)Java网络编程之IO模型篇-内核Select、Poll、Epoll多路复用函数源码深度历险!
select/poll、epoll这些词汇相信诸位都不陌生,因为在Redis/Nginx/Netty等一些高性能技术栈的底层原理中,大家应该都见过它们的身影,接下来重点讲解这块内容。

推荐镜像

更多