spring 定时任务、调用过程

网上介绍:http://gong1208.iteye.com/blog/1773177

一。常见用法:

1.任务类:

public class JobHandler {
	
	public void cleanLog() {
		logger.info("--开始执行删除日志任务--");
	}

}
2.spring xml配置:

	
	<!-- 工作的bean -->
	<bean id="cleanLog" class="com.core.util.JobHandler" />

	<!-- job的配置开始 -->
	<bean id="myJob" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
		<property name="targetObject">
			<ref bean="cleanLog" />
		</property>
		<property name="targetMethod" value="cleanLog">
		</property>
	</bean>
	<!-- job的配置结束 -->

	<!-- 调度的配置开始 -->
	<bean id="crontestJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
		<property name="jobDetail">
			<ref bean="myJob" />
		</property>
		<property name="cronExpression">
			<value>0 0 1 * * ?</value>
		</property>
	</bean>
	
	<!--
		cronExpression调度7个参数所代表的含义
		字段	 		允许值	 			允许的特殊字符
		秒	  		0-59	  			, - * /
		分	  		0-59	  			, - * /
		小时	  		0-23	  			, - * /
		日期	  		1-31	  			, - * ? / L W C
		月份	  		1-12 或者 JAN-DEC	<span style="white-space:pre">	</span>, - * /
		星期	  		1-7 或者 SUN-SAT	  	, - * ? / L C #
		年(可选)	<span style="white-space:pre">	</span>留空, 1970-2099		<span style="white-space:pre">	</span>, - * /
	-->
	<!-- 调度的配置结束 -->


	<!-- 启动触发器的配置开始 -->
	<bean name="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
		<property name="triggers">
			<list>
				<ref bean="crontestJobTrigger" />

			</list>
		</property>
	</bean>
	<!-- 启动触发器的配置结束 -->

二、实例一,定时调用存贮过程

1.xml定时配置

<!-- 每天2点自动跑存储过程定时器 -->
	<bean id="bean" class="org.springframework.aop.framework.ProxyFactoryBean">
			<property name="target">
				<bean class="com.cc.Proc">
					<property name="jdbcTemplate">
						<ref bean="jdbcTemplate" />
					</property>
				</bean>
			</property>
			<property name="proxyTargetClass">
				<value>true</value>
			</property>
		</bean>   
	<bean id="executeProc" class="org.springframework.scheduling.quartz.CronTriggerBean">
		<property name="jobDetail">
			<bean
				class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
				<property name="targetObject" ref="bean" />
				<property name="targetMethod" value="executeProc" />
			</bean>
		</property>
		<property name="cronExpression">
			<value>0 0 2 * * ?</value>
		</property>
	</bean>
		
	<bean id="scheduler"
		class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
		<property name="triggers">
			<list>
			 <!-- <ref bean="executeProc1" />-->
				<ref bean="executeProc" />
			</list>
		</property>
	</bean>
2.执行存储过程类Proc

package com.cc;

import java.sql.CallableStatement;
import java.sql.SQLException;

import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.CallableStatementCallback;
import org.springframework.jdbc.core.JdbcTemplate;

public class Proc{

    private JdbcTemplate jdbcTemplate;
    private String a;
    private String b;

    public void executeProc() {
	String sqlProc = "{call PROC(?,?,?,?)}";
	String strProc = (String) jdbcTemplate.execute(sqlProc, new CallableStatementCallback() {
	    @Override
	    public Object doInCallableStatement(CallableStatement cs) throws SQLException, DataAccessException {
		cs.setString(1, a);// 输入参数
		cs.setString(2, b);// 输入参数
		cs.registerOutParameter(3, java.sql.Types.VARCHAR);// 输出参数
		cs.registerOutParameter(4, java.sql.Types.VARCHAR);// 输出参数
		cs.execute();
		System.out.println("Proc code=" + cs.getString(3) + ":::Proc message=" + cs.getString(4));
		return cs.getString(3);
	    }
	});
	System.out.println(strProc);
    }

    public JdbcTemplate getJdbcTemplate() {
	return jdbcTemplate;
    }

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
	this.jdbcTemplate = jdbcTemplate;
    }

    public String getA() {
	return this.a;
    }

    public void setA(String a) {
	this.a = a;
    }

    public String getB() {
	return this.b;
    }

    public void setB(String b) {
	this.b = b;
    }
}
3.执行的存储过程PROC

CREATE OR REPLACE 
procedure PROC(a in varchar2,
               b in varchar2,
               code out varchar2,
               message out varchar2) is
  a1 varchar2(10);
  b1   varchar2(10);
begin
  a := to_char(to_date(a, 'yyyy-MM-dd') - 1,'yyyy-MM-dd');
  b   := to_char(to_date(b, 'yyyy-MM-dd'),'yyyy-MM-dd');
  
  code    := SQLCODE;
  msg := SUBSTR(SQLERRM, 1, 100);
  dbms_output.put_line(code || '::' || message);
end PROC;


三、。。。。。。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值