数据库触发java_如何oracle数据更新时触发java代码

展开全部

oracle数据更新e68a8462616964757a686964616f31333337623463时触发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;


版权声明:本文为weixin_36280338原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。