请问 StringBuffer 在 oracle 中用什么代替???

Sandrer 2019-10-12 07:51:51
工作需要一直使用 oracle 数据库, 但某些功能 plsql 实现不了, 于是尝试接触 java
用 java 写了一个类, 其中某个函数使用了 StringBuffer 作为输出
因为这个函数需要返回两个 int 类型的值, 函数返回值已经用了一个 int 了, 而听说 java 函数不能想 c/c++ 那样直接用 int 引用, 所以就使用了 StringBuffer 作为出参

类编写完毕后, 其中一个没有 StringBuffer 的函数成功在 oracle 中执行
但带有 StringBuffer 的函数, 在 oracle 中死活执行不了

create or replace function oracle_test_java2
(
key varchar2,
text varchar2,
value out varchar2
) return number
is language java name 'myjava.test2(java.lang.String, java.lang.String, java.lang.StringBuffer) return int';


public static int test2(String key, String text, StringBuffer value)


应该怎样解决???
...全文
143 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qybao 2019-10-21
  • 打赏
  • 举报
回复
引用 3 楼 Sandrer 的回复:
language java name 'myjava.test2(java.lang.String, java.lang.String, java.lang.StringBuffer) return int';
language java name 'myjava.test2(java.lang.String, java.lang.String, java.lang.String) return int';
请问是不是将红色的地方改成蓝色的???


你调用oracle的参数用String,你要把String返回到你的java方法的外部,要用StringBuffer
void test(String s) {
callOralce(s); //你这个s返回不到test方法外
}

void test(StringBuffer s) {
String s1 = "";
callOracle(s1); //orcale没有StringBuffer,所以调用时用String
s.append(s1); //这样test外才能获得s1
}
ml_dark 2019-10-21
  • 打赏
  • 举报
回复
oracle没有对应的StringBuffer的,不过这个地方用String不就行了吗?
Sandrer 2019-10-18
  • 打赏
  • 举报
回复
引用 2 楼 qybao 的回复:


在 java 里面测试的话, 我是有按照你所说的传参前 new 一个 StringBuffer 对象
然后在函数内部 append 到这个参数的
java 里测试输出是可以得到有参数设置的值, 但到了 oracle 中就一直出错
我试试在 oracle 里面把 StringBuffer 改为 String 试试
Sandrer 2019-10-18
  • 打赏
  • 举报
回复
引用 2 楼 qybao 的回复:
你传参数时要new 一下StringBuffer,否则是个null对象
也就是类似于
StringBuffer sb = new StringBuffer();
test2(key, text, sb);这样调用
调存储过程时用一个String参数代替StringBuffer,否则oracle不认识该参数类型的,然后把返回的String结果append到sb里,这样结果就能传到方法外了


language java name 'myjava.test2(java.lang.String, java.lang.String, java.lang.StringBuffer) return int';
language java name 'myjava.test2(java.lang.String, java.lang.String, java.lang.String) return int';

请问是不是将红色的地方改成蓝色的???
qybao 2019-10-12
  • 打赏
  • 举报
回复
你传参数时要new 一下StringBuffer,否则是个null对象 也就是类似于 StringBuffer sb = new StringBuffer(); test2(key, text, sb);这样调用 调存储过程时用一个String参数代替StringBuffer,否则oracle不认识该参数类型的,然后把返回的String结果append到sb里,这样结果就能传到方法外了
Sandrer 2019-10-12
  • 打赏
  • 举报
回复
在 oracle 中, 参数 value 中如果不带 out 关键字
在测试存储过程时, value 不赋值的话会报 ORA-29532 java 调用被未捕获的 java 异常错误终止: java.lang.NullPointerException
如果测试时随便给它赋一个值, 就会报 ORA-00932: 数据类型不一致: 应为 an IN argument at position 3 that is an instance of an Oracle type convertible to an instance of a user defined java class, 但去获得 an Oracle type...

如果参数 value 中带上 out 关键字, 则存储过程根本编译不过, 报错 PLS-00235: 外部类型不适用于此参数

51,397

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧