原文地址:在PLSQL中编译复杂的java

PLSQL中可以编译运行JAVA程序。

一个简单的例子:

create or replace and compile java source named xxfnd as package xxfnd;
public class Test{
  public void Test(){
  }

public static String  helloWorld{
          
  return "success";
 
  }
}

但是如果真的想在PLSQL中用JAVA做成什么事情,这样的程度是不够的。

需要在PLSQL中使用JAVA的原因

1. JAVA作为开源跨平台的语言,提供了丰富的工具包,可以处理很多复杂的内容,如操作EXCEL,发布Service等等;

2. Oracle开发中有些事情只能用PLSQL来做。比如工作流。

而当我们需要在工作流中借助JAVA完成复杂任务时,需要引用很多jar包。

本文介绍一个完整的例子,在PLSQL中实现复杂的JAVA程序调用。

1. 导入java程序所需jar包。这是很关键的一步。很多文章都语焉不详。

上传所需jar包至应用服务器,这里假设绝对路径为:

/home/applqv/pushjar/

telnet至应用服务器。

sqlplus /nolog
connect sys/pass as sysdba;

使用如下语法将jar包加载至数据库:

call dbms_java.loadjava('-v -r  PUBLIC -synonym /home/applqv/pushjar/axis.jar');
在导入中可能会报错,但是报错的时候,大部分jar包中的class文件应该已经成功加载了。所以有时候可以

忽略这个报错。

可以用以下SQL查询已经成功加载的class

select * from dba_objects where object_type='JAVA CLASS' AND OBJECT_NAME LIKE '%com/ibm/wsdl%'

可以在数据库parameter user_dump_dest  路径中找到dbms_java.loadjava的trace文件。其中会有详细的log记录。

每次执行dbms_java.loadjava都会有trace。

2. 在PLSQL中编写java程序。可以直接将按照以下语法写好的java程序贴到PLSQL中,然后F8编译。

create or replace and compile java source named xxfnd as package xxfnd;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;

import java.util.HashMap;
import java.util.Map;

import javax.xml.namespace.QName;

import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
public class Test{
  public void Test(){
  }

public static String  helloWorld(String a){
          
 
   String url = "http://172.2.2.1/wms/services/ws";
        try{
        Service service = new Service();
       
        org.apache.axis.client.Call call = (org.apache.axis.client.Call)service.createCall();
       
        call.setTargetEndpointAddress(url);
        call.setOperationName(new QName("null", "push"));
        Map map = new HashMap();
             for (String key: map.keySet()) {
            String sreMessage =
                "{"Push": [{"username": "" + key + "","appname": "BG_405","pushcontents": "" +
                map.get(key) + ""}]}  ";
            System.out.println("请求:" + sreMessage);
            System.out.println("返回:" +
                               call.invoke(new Object[] { sreMessage }));
           System.out.println( "aaa"+call.getMessageContext().getCurrentMessage().getMessageType());                  
        }
      
        }
        catch(Exception e){
          
        }
  return "success";  
  }
}
3. 查看编译是否出错:

show errors java source xxfnd;

4.将java程序封装在PLSQL包中:

create or replace package test_pkg is
  function hello_world(a varchar2) return varchar2;
end test_pkg;
/

create or replace package body test_pkg is
  function hello_world(a varchar2) return varchar2 is
    language java name 'xxfnd.Test.helloWorld(java.lang.String) return String';
end test_pkg;
/

5. 至此,java程序已经可以调用了。

在PLSQL中编译复杂的java(转)的更多相关文章

  1. 在 Sublime Text 2 中编译和运行 Java 程序,以及输出中文出错问题解决办法

    Sublime Text 2 是我最喜欢用来编码的文本编辑器,如果你尝试使用后相信你也会喜欢上它的.在这篇文章中我们将讨论如何在 Sublime Text 2 中编译和运行 Java 程序. 第一步: ...

  2. 【Java】【转】在命令行中编译和运行java

    原文:http://blog.csdn.net/u010900574/article/details/50792353 同时加载编译多个jar包和java文件 在个人平常使用或者当我们把代码部署到Li ...

  3. 在linux命令行中编译和运行java文件

    同时加载编译多个jar包和java文件 在个人平常使用或者当我们把代码部署到linux服务器上的时候,我们经常需要通过命令行编译和运行java文件,网上关于这个的方法大多是通过 javac -cp f ...

  4. 记录5-如何在UltraEdit中编译和运行Java

    1点击“高级”,再点击“工具配置” 2点击“插入”,在“菜单项”名称上输入“编译java程序”,在“命令行”里输入“javac %n%e”,在工作目录上填“%p”. 3切换到“输出”项,选择“输出到列 ...

  5. Java 7 中的Switch 谈 Java版本更新和反编译知识

    Java 7 中的Switch 谈 Java版本更新和反编译知识          学习编程,享受生活,大家好,我是追寻梦的飞飞.今天主要讲述的是Java7中的更新Switch实现内部原理和JAD反编 ...

  6. 在CMD窗口中使用javac和java命令进行编译和执行带有包名的具有继承关系的类

    一.背景 最近在使用记事本编写带有包名并且有继承关系的java代码并运行时发现出现了很多错误,经过努力一一被解决,今天我们来看一下会遇见哪些问题,并给出解决办法. 二.测试过程 1.父类代码 pack ...

  7. idea中编译项目报错 java: javacTask: 源版本 1.8 需要目标版本 1.8

    问题如上面所叙: > idea中编译项目报错 java: javacTask: 源版本 1.8 需要目标版本 1.8 解决方案: > Setting->Compiler->Ja ...

  8. Centos下命令行编译MapReduce代码(Java)并打包在Hadoop中执行

    前提条件:搭建好Hadoop系统 新建文件夹:input  和  output hdfs dfs -mkdir /inputhdfs dfs -mkdir /output 查看文件系统 hdfs df ...

  9. cmd中编译java脚本 (2013-05-02-bd 写的日志迁移

    此前提是已经搭建好了jdk的编译环境! 先写一个java脚本如:建立一个HelloWord.java //public : 表示此类是公共的 一个java文件中只能有一个public类 //class ...

随机推荐

  1. 【读书笔记】iOS-NSPredicate

    一,Cocoa提供了一个名为NSPredicate的类,它用于指定过滤器的条件.可以创建NSPredicate对象,通过该对象准确地描述所需的条件,对每个对象通过谓词进行筛选,判断它们是否与条件相匹配 ...

  2. IOC基础

    Ioc-Inversion of Control,即"控制反转",不是什么技术,而是一种设计思想.在Java开发中,Ioc意味着将你设计好的对象交给容器控制,而不是传统的在你的对象 ...

  3. 关于在Xcode的OC工程中相对路径失败的原因

    Xcode的工程生成的可执行文件不是默认在源文件同一个目录下面的,所以当可执行文件执行的时候,相对路径就不对了. 这一点用终端直接编译执行文件证明了这一点: clang -fobjc-arc -fra ...

  4. 调研Android平台的开发环境的发展演变

    ·  安卓是以linux为基础的开放源码操作系统.因为安卓的开源等原因,所以现在市场上会有大量的APP可供使用,且各个方面都功能强大. ·  也许是因为开源的原因,安卓过于碎片化.每个APP互相独立. ...

  5. python数据结构-列表-基本操作

  6. jQuery Validate 表单验证插件----Validate简介,官方文档,官方下载地址

     一. jQuery Validate 插件的介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆 ...

  7. C#删除文件和文件夹到回收站

    首先对项目添加名为Microsoft.VisualBasic.dll的引用,然后添加命名空间using Microsoft.VisualBasic.FileIO;usingSystem;namespa ...

  8. Vert.x入门体验

    Vert.x入门体验 一.概述 Vert.x(http://vertx.io)是一个基于JVM.轻量级.高性能的应用平台,非常适用于最新的移动端后台.互联网.企业应用架构. 二.安装配置 访问Vert ...

  9. 如何在TFS的过程模板中添加报表

    在新建团队项目的过程中,TFS的"新建团队项目向导"会根据用户选择的过程模板类型(CMMI, Scrum,Agile等)自动为团队项目创建一个SSRS(SQL Server Rep ...

  10. ZooKeeper系列2:ZooKeeper的运行

    问题导读1.如何启动ZooKeeper 服务?2.如何启动集群 1)单机模式 用户可以通过下面的命令来启动 ZooKeeper 服务: zkServer.sh start 复制代码 这个命令默认情况下 ...