首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORA-06553错误参数与java函数在Oracle中的Blob

ORA-06553错误参数与java函数在Oracle中的Blob
EN

Stack Overflow用户
提问于 2015-03-06 23:52:39
回答 1查看 665关注 0票数 1

我试图在Oracle 11g中实现一个函数,该函数调用一个java类来解密Blob图像信息。

一切似乎都是正确的,但我得到了一个ORA-06553 PLS-306“错误的数目或类型的论点”。

函数接受blob并返回blob,因此我不知道错误来自何处。

PL/SQL函数:

代码语言:javascript
复制
create or replace
function decrypt_image return blob as
language JAVA name 'Imageutil.decryptBlobImage (java.sqlBlob) return java.sqlBlob';

Java函数:

代码语言:javascript
复制
public class Imageutil
public static java.sql.Blob decryptBlobImage (java.sql.Blob img) throws Exception {
    try {
        int len = (int)img.length();
        byte[] imagearray = img.getBytes(1, len);
        byte[] decrypted = Encryptor.decryptBinary(imagearray);
        Blob retval = new SerialBlob(decrypted);
        return retval;
    } catch (SQLException ex) {
        ex.printStackTrace();
        throw new Exception("Error handling blob",ex);
    }
}
}

数据列在一个表格中:

代码语言:javascript
复制
temp_image(id number, image blob, decrypted blob);

我在试着

代码语言:javascript
复制
update temp_image set decrypted = decrypt_image(image);

当我发现错误的时候。每次生成一个Oracle trc文件,但似乎没有错误:

代码语言:javascript
复制
========= Dump for error ORA 1110 (no incident) ========
----- DDE Action: 'DB_STRUCTURE_INTEGRITY_CHECK' (Async) -----

(然后对数据库进行完整性检查)。

该函数工作正常,原始数据是长的原始数据,我可以对数据进行十六进制转储,并对其进行解密。测试表是由原始长原始数据上的to_lob()函数加载的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-06 23:59:24

在PL/SQL声明中,您似乎使用了java.sqlBlob而不是java.sql.Blob;但是您也没有在该declaraion中为您的函数提供参数:

代码语言:javascript
复制
create or replace
function decrypt_image (original_blob blob) return blob as
language JAVA name 'Imageutil.decryptBlobImage (java.sql.Blob) return java.sql.Blob';

在您的版本中,PL/SQL函数不带参数,所以当您调用它为decrypt_image(image)时,您传递的参数数量是错误的--它只期望传递一个参数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28909622

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档