loadjava似乎工作但查询不适用于oracle sql开发人员

时间:2014-06-20 16:44:52

标签: plsql oracle-sqldeveloper loadjava

我正在尝试将一个java类作为函数加载到oracle。在服务器中,我设法使用loadjava,如下所示:

C:\Users\n12017>loadjava -user USER1/passw E:\JAVA_repository\SOOSProjects\Mehmet_java_2db_trial\classes\mehmet_java_2db_trial\kondrakk.class

在oracle db方面:

create or replace function ngram_kondrakk(src in varchar2, trg in varchar2)
  return float
as language java
  name 'mehmet_java_2db_trial/kondrakk.getDistance(java.lang.string, java.lang.string) return java.lang.float';
/

但是,当我按如下方式应用查询时,出现错误。 (作为查询的结果,我预计相似性得分为1,因为比较了两个相同的字符串)

select ngram_kondrakk('mehmet','mehmet') from dual;

这是错误:

ORA-29532: Java call terminated by uncaught Java exception: System error : java/lang/UnsupportedClassVersionError
29532. 00000 -  "Java call terminated by uncaught Java exception: %s"
*Cause:    A Java exception or error was signaled and could not be
           resolved by the Java code.
*Action:   Modify Java code, if this behavior is not intended.

最后,这是我尝试使用的代码:

package mehmet_java_2db_trial;
公共类kondrakk {

public static float getDistance(String source, String target) {
  final int sl = source.length();
  final int tl = target.length();

  if (sl == 0 || tl == 0) {
    if (sl == tl) {
      return 1;
    }
    else {
      return 0;
    }
  }

  int n=3;

  int cost = 0;
  if (sl < n || tl < n) {
    for (int i=0,ni=Math.min(sl,tl);i<ni;i++) {
      if (source.charAt(i) == target.charAt(i)) {
       cost++;
      }
    }
    return (float) cost/Math.max(sl, tl);
  }

  char[] sa = new char[sl+n-1];
  float p[]; //'previous' cost array, horizontally
  float d[]; // cost array, horizontally
 float _d[]; //placeholder to assist in swapping p and d

  //construct sa with prefix
  for (int i=0;i<sa.length;i++) {
    if (i < n-1) {
      sa[i]=0; //add prefix
    }
    else {
      sa[i] = source.charAt(i-n+1);
    }
  }
  p = new float[sl+1]; 
  d = new float[sl+1]; 

  // indexes into strings s and t
  int i; // iterates through source
  int j; // iterates through target

  char[] t_j = new char[n]; // jth n-gram of t

 for (i = 0; i<=sl; i++) {
     p[i] = i;
 }

 for (j = 1; j<=tl; j++) {
     //construct t_j n-gram 
     if (j < n) {
     for (int ti=0;ti<n-j;ti++) {
         t_j[ti]=0; //add prefix
       }
       for (int ti=n-j;ti<n;ti++) {
         t_j[ti]=target.charAt(ti-(n-j));
       }
     }
     else {
       t_j = target.substring(j-n, j).toCharArray();
     }
     d[0] = j;
     for (i=1; i<=sl; i++) {
         cost = 0;
         int tn=n;
         //compare sa to t_j
         for (int ni=0;ni<n;ni++) {
           if (sa[i-1+ni] != t_j[ni]) {
             cost++;
           }
           else if (sa[i-1+ni] == 0) { //discount matches on prefix
             tn--;
           }
       }
         float ec = (float) cost/tn;
         // minimum of cell to the left+1, to the top+1, diagonally left and up +cost
         d[i] = Math.min(Math.min(d[i-1]+1, p[i]+1),  p[i-1]+ec);
     }
     // copy current distance counts to 'previous row' distance counts
     _d = p;
     p = d;
     d = _d;
 }

 // our last action in the above loop was to switch d and p, so p now
 // actually has the most recent cost counts
 System.out.println(1.0f - (p[sl] / Math.max(tl, sl)));
 return 1.0f - (p[sl] / Math.max(tl, sl));

} 

}

请帮助!

提前致谢...

2 个答案:

答案 0 :(得分:0)

你的plsql包装函数有&#34; /&#34;

...mehmet_java_2db_trial/kondrakk.getDistance...

/ 替换为 [dot]

检查docs 并且正如已经提到的那样 - 将JVM的编译与JVM同步用于运行时(将是&#34;附加&#34;到DB的Oracle JVM)

答案 1 :(得分:0)

在编译Java类以加载到Oracle数据库时,请确保编译Java类以与Oracle数据库中的JVM一起运行。

与当前Java相比,Oracle数据库附带的Java版本通常已过时:期望将Java 1.4与Oracle 10g和1.5一起使用。您最好的选择是使用数据库附带的Java编译器,但是如果您不能这样做,请使用-target 1.5等强制编译器编译类以在Java 1.5上运行。