在PL/SQL中借助JAVA调用可执行程序的例子

本文介绍了一个在Oracle数据库中使用Java实现的TNS Ping工具。该工具通过调用tnsping命令来检查数据库连接状态,并返回相应的结果。文章包含创建Java类、授予Java权限及定义函数的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*replace the username*/
call dbms_java.grant_permission( 'FRGT_UAT', 'SYS:java.io.FilePermission', '<<ALL FILES>>', 'execute' );

create or replace java source named "JTns"
as
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.IOException;
public class JTns {
public static String getfing(String seed){
/* Note: when this error occured
ORA-29532: Java call terminated by uncaught Java exception: java.lang.NullPointerException
just place the full path of the exe
ex:
String command = "/home/oracle/product/9.2/bin/tnsping " + seed;
*/
String command = "tnsping " + seed;
String pingres = null;
Process process;
InputStreamReader ir = null;
char c[] = new char[1024];
try{
process = Runtime.getRuntime().exec(command);
ir = new InputStreamReader(process.getInputStream());
while(ir.read(c, 0, 1024) != -1){
pingres = new String(c);
}
ir.close();
} catch(IOException io){ };
if (pingres == null) pingres = "Cant Find TNSPING";
return pingres.trim();
}
};
/

create or replace function GetTnsPing(sid varchar2) return varchar2
as language java
name 'JTns.getfing(java.lang.String) return java.lang.String';
/

create or replace function isSeedUp(sid varchar2) return boolean
as
stat boolean := false;
res varchar2(32767) := gettnsping(sid);
begin
stat := case
when instr(res,'OK') > 0 then true
else false
end;
return stat;
end;
/

### 如何在 Oracle 数据库中调用存储过程 #### 使用 PL/SQL 调用存储过程 可以在 SQL*Plus 或其他支持 PL/SQL 的工具中通过匿名PL/SQL块来调用存储过程。下面是一个简单的例子: ```sql BEGIN my_procedure_name(param1 => value1, param2 => value2); END; / ``` 这里 `my_procedure_name` 是要调用的存储过程的名字,而 `param1`, `param2` 则是该存储过程所需的参数名称及其对应的值[^3]。 对于具有输出参数的情况,则需要先声明变量接收这些返回值: ```sql DECLARE output_value datatype; BEGIN my_procedure_with_output_param(output_param => output_value); DBMS_OUTPUT.PUT_LINE('Output parameter is ' || output_value); END; / ``` 此段代码展示了如何定义局部变量 `output_value` 来保存由 `my_procedure_with_output_param` 返回的数据,并利用 `DBMS_OUTPUT.PUT_LINE()` 显示结果[^1]。 #### 通过应用程序接口调用 当从外部编程环境如 Java 应用程序访问时,可借助JDBC API提供的功能实现对Oracle存储过程的调用。这通常涉及到使用 CallableStatement 对象以及相应的转义语法格式化字符串构建查询请求[^4]: ```java String storedProcCall = "{call MY_PROCEDURE_NAME(?, ?)}"; CallableStatement cstmt = conn.prepareCall(storedProcCall); // 设置输入参数 cstmt.setString(1, "inputValue"); // 注册输出参数 cstmt.registerOutParameter(2, Types.VARCHAR); // 执行调用 cstmt.execute(); // 获取输出参数的结果 String result = cstmt.getString(2); ``` 这段Java代码片段说明了怎样准备一个针对名为 `MY_PROCEDURE_NAME` 的存储过程的调用命令,设置必要的输入参数,指定预期会得到哪些类型的输出数据,最后执行这个操作并读取任何产生的输出信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值