如何oracle数据更新时触发java代码
oracle数据更新时触发java代码的步骤如下:
1。编写JAVA程序
public class Main {
public static void modify(String statTime)
{
String datas = "/var/spool/cron/oracle";
File data = new File(datas);
StringBuffer backup = null;
try {
StringBuffer content = new StringBuffer();
backup = new StringBuffer();
BufferedReader san = new BufferedReader(new FileReader(data));
String line = null;
while((line=san.readLine())!=null)
{
backup.append(line);
backup.append("/n");
}
content.append("15 ");
content.append(statTime.trim());
content.append(" * * * /home/oracle/task.sh");
content.append("/n");
content.append("13 ");
content.append(statTime.trim());
content.append("* * * /home/oracle/tj_task/task2.sh");
content.append("/n");
FileWriter writer = new FileWriter(data,false);
writer.write(content.toString());
writer.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
try
{
FileWriter writer = new FileWriter(data,false);
writer.write(backup.toString());
writer.flush();
}catch(Exception ex)
{
ex.printStackTrace();
}
}
}
}
注意,这里写JAVA程序不需要遵循标准的JAVA程序,一定要有main入口函数,相反,这里的函数一般不要取名为main,除非格式是标准的main 函数格式
2。把JAVA程序LOAD进oracle
在$ORACLE_HOME/bin目录下有个LOADJAVA命令,使用这个命令将刚写好的JAVA程序LOAD进数据库。
loadjava -user test/test@test -o -v -f -r Main.java
如果成功的话,会打印出来信息提示成功,若程序有编译错误的话,也会提示错误的地方。
3。修改权限
首先以管理员身份登录进数据库
sqlplus / as sysdba
然后执行
begin
dbms_java.grant_permission('TEST','SYS:java.io.FilePermission','/var/spool/cron/oracle','read,write,execute,delete');
end;
/
执行完毕后,在数据库里执行上述JAVA程序时,就拥有读写该文件的权限了。
4。创建存储过程
进入到数据库,在SQLPLUS命令行
create or replace procedure Modify(name varchar2) as language java name 'Main.modify(java.lang.String)';
/
会提示创建存储过程成功。
5。增加trigger
TOAD里直接针对某个表增加trigger,所以关键部分的代码
begin
if :old.name = 'time' then
Modify(:new.value);
end if;
end;
我知道java可以通过api来访问oracel,我就是有这么个需求!谢谢
这个技术还确实有
1.新建一个java source
create or replace and compile java source named j_source as
public class j_class{
public static String j_socket(String str)
{
//socket连接客户端发送给客户端
}
}
2.新建一个function
create or replace function fun_call_java(str VARCHAR2) return VARCHAR2 as
language java name j_class.j_socket(java.lang.String) return java.lang.String ';
3.写一个触发器
当有记录更新时,调用function fun_call_java,然后由oracle的java source通知客户端