<%@ page contentType="text/html; charset=gb2312"%> 在unix下让oracle定时执行*.sql文件
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
在unix下让oracle定时执行*.sql文件
     发布者: 发布时间:2007-01-24

oracle数据库自带的dbms_job功能可以实现定时执行pl/sql的存储过程,但是如果sql语句很复杂,sql语句很多,以及经常要改变sql语句的写法,用写pl/sql存储过程的方法再定时执行会比较繁琐。何况还有一些unix系统管理员不会写pl/sql存储过程,所以我介绍一个简单的shell程序可以在安装了oracle server或client的unix机器上实现定时执行一个*.sql文件。

首先我们在安装了oracle server或client的unix机器上连接目的数据库:

$sqlplus username/password@servie_name


如果能够成功进入sql>状态,并执行简单的sql语句

sql> select sysdate from dual;


表明连接成功,否则检查/$oracle_home/network/admin/tnsnames.ora里servie_name是否正确定义。

/etc/hostname里是否包含目的数据库的主机名等等(其它的网络检查就不在这里详细列举了)。

接着在scott用户下运行测试的sql语句:scott_select.sql

sql> select d.dname,e.ename,e.job,e.hiredate 	from emp e,dept d 	where to_char(e.hiredate,''yyyy'')=''1981'' and e.deptno=d.deptno;


然后在目录/oracle_backup/bin/下写一个类似下面的shell文件scott_select.sh

------------------------------------------------------------------------    		su - oracle -c "sqlplus scott/tiger@servie_name"<<eof	spool /oracle_backup/log/scott_select.txt;	@/oracle_backup/bin/scott_select.sql;	spool off;	exit; -------------------------------------------------------------------------


说明:

spool语句把scott_select.sql语句的执行结果输出到/oracle_backup/log/scott_select.txt文件

@符号是执行/oracle_backup/bin/scott_select.sql文件

在要执行的*.sql文件里可以存放dml、ddl等多条sql语句。

改变scott_select.sh的属性成755, 可以执行

$chmod 755 /oracle_backup/bin/scott_select.sh


这样,unix系统管理员(root权限)可以利用crontab命令把scott_select.sh加入定时操作队列里。

或者直接编辑os下的配置文件:

sun solaris	文件	/var/spool/cron/crontabs/root    linux	文件	/var/spool/cron/root


在root文件后面添加一行(含义:每月的18日4:40分执行scott_select.sh)

40 4 18 * * /oracle_backup/bin/scott_select.sh


时间表按顺序是:分钟(0—59) 小时(0—23) 日期(1—31) 月份(1—12) 星期几(0—6)

您可以根据不同的需求来组合它们。

重新启动os的定时服务,使新添加的任务生效。

sun solaris    #/etc/rc2.d/s75cron stop    #/etc/rc2.d/s75cron start    linux    #/etc/rc.d/init.d/crond restart


这样oracle数据库就会定时执行scott_select.sql文件,并把结果输出到os文件scott_select.txt。

如果我们要新写或者修改scott_select.sql文件,直接编辑它就可以了。

(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
如何在oems中成功提交作业
oracleweb应用开发之apache架设与pl/sql页面设计(2)
oracleweb应用开发之apache架设与pl/sql页面设计(3)
oraclee-business套件rra/fndfs泄露任意文件漏洞的修补
如何学习oracle?
oraclenetserviceslink查询请求缓冲区溢出漏洞的修补
 
最近评论:
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(4206)
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(9603)
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(9794)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(7112)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(140)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(5792)
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号