网站建设资讯

NEWS

网站建设资讯

Oracle的包如何触发,oracle如何执行包

oracle怎么用复制的包

1、首先打开电脑,点击进入浏览器。

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站建设、网站设计、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的蓬莱网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

2、其次点击搜索oracle,选择第一个进入,点击选择数据化,选择复制的包,点击使用。

3、最后点击确认即可。

如何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;

如何建立oracle包,如何调用包的过程或是函数

包用于在逻辑上组合过程和函数,它由包规范和包体两部分组成

1.创建包

--创建一个包sp_package

create package sp_package is

--声明该包有一个过程和函数,(没有实现)

procedure update_sal(name varchar2,newsal number);

function annual_nicome(name varchar2) return number;

end;

--创建包体(用于实现已经声明的函数和过程)

create package body sp_package is

procedure update_sal(name varchar2,newsal number)

is

BEGIN

UPDATE emp

SET    sal = newsal

WHERE  ename = name;

END;

function annual_income(name varchar2)

return number is

annual_salary number;

BEGIN

SELECT sal * 12 + Nvl(comm,0)

INTO   annual_salary

FROM   emp

WHERE  ename = name;

RETURN annual_salary;

END;

end;

--调用包中的内容

exec sp_package.update_sal('name',number);

oracle包中怎么声明触发器?本包中的函数怎么调用本包中的存储过程?

触发器怎么写在包里了?

包里的函数调存储过程很简单的,直接用就可以了,传入对应的参数,不需要加包名前缀

oracle 数据库包怎么运行

如果你使用界面的话,就直接双击图标,如果使用脚本的话,就从开始程序里打开Oracle plus

,这两者都要保证你的服务是否启动,一般启动最后两个就可以

1.cmd进入命令行 lsnrctl start 启动监听服务,看出现什么错误

如果没有错误,察看数据库是否可以正常进行连接

2.看下你电脑是不是装了防火墙 先把防火墙禁止掉去

3.去orant\net80\trace\看看,一般有错都会在那里产生一个.log文件

怎么调用oracle里的包

在存储过程或函数里调用oracle包的话,首先要有执行这个包的权限;如果包属于其他的用户(不是系统包),调用时:用户名.包名.存储过程(参数)名或者

变量:=用户名.包名.函数(参数);因为函数有返回值,变量类型要跟函数返回值的类型一致。

在command

下调用的话:exec

用户名.包名.存储过程名(参数);select

用户名.包名.函数名(参数)

from

dual;就可以了。包属于当期用户可以不写用户名。


网站标题:Oracle的包如何触发,oracle如何执行包
分享路径:http://cdweb.net/article/dseshhj.html