首先繼承java.util.TimerTask類實現run方法java
import java.util.Date; import java.util.TimerTask; public class TimerTest extends TimerTask { @Override public void run() { // TODO Auto-generated method stub System.out.println("TimerTest"+(new Date()).toString()); } }
Spring配置算法
<bean id="TimerTest" class="com.land.TimerTest"> </bean> <bean id="TimerTestTask" class="org.springframework.scheduling.timer.ScheduledTimerTask"> <!-- wait 10 seconds before starting repeated execution --> <property name="delay" value="10000" /><!-- 啓動後的延遲時間--> <!--間隔時間--> <property name="period" value="72000" /> <property name="timerTask" ref="TimerTest" /> </bean> <bean id="timerFactory" class="org.springframework.scheduling.timer.TimerFactoryBean"> <property name="scheduledTimerTasks"> <list> <!-- see the example above --> <ref bean="TimerTestTask" /> </list> </property> </bean>
首先繼承QuartzJobBean類實現executeInternal方法spring
public class SchedulerTest extends QuartzJobBean{ @Override protected void executeInternal(JobExecutionContext arg0) throws JobExecutionException { // TODO Auto-generated method stub //System.out.println("-----------"); System.out.println("1111111"+(new Date()).toString()); } }
-------------------------------------------sql
public class SchedulerTest2 extends QuartzJobBean{數據庫
@Override
protected void executeInternal(JobExecutionContext arg0) throws JobExecutionException {
// TODO Auto-generated method stub
//System.out.println("-----------");
System.out.println("22222222"+(new Date()).toString());
}安全
}ide
<bean id="SchedulerTask" class="org.springframework.scheduling.quartz.JobDetailBean"> <property name="jobClass"> <value>com.land.SchedulerTest</value> </property> </bean> <bean id="SchedulerTask2" class="org.springframework.scheduling.quartz.JobDetailBean"> <property name="jobClass"> <value>com.land.SchedulerTest2</value> </property> </bean> <bean id="SchedulerTaskTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean"> <property name="jobDetail" ref="SchedulerTask" /> <property name="cronExpression"> <value>0/10 * * * * ?</value> </property> </bean> <bean id="SchedulerTaskTrigger2" class="org.springframework.scheduling.quartz.SimpleTriggerBean"> <property name="jobDetail" ref="SchedulerTask2" /> <property name="startDelay"> <value>1000</value><!--延遲時間--> </property> <property name="repeatInterval"> <value>20000</value><!--間隔時間--> </property> </bean> <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="triggers"> <list> <ref bean="SchedulerTaskTrigger" /> <ref bean="SchedulerTaskTrigger2" /> </list> </property> </bean>
Java Timer定時有一種配置啓動的方org.springframework.scheduling.timer.ScheduledTimerTask,性能
Quartz定時器有兩種配置啓動的方式:org.springframework.scheduling.quartz.SimpleTriggerBean,org.springframework.scheduling.quartz.CronTriggerBean。spa
org.springframework.scheduling.quartz.CronTriggerBean.net
Linux系統的計劃任務一般有cron來承擔。從左到右
字段 容許值 容許的特殊字符 秒 0-59 , - * / 分 0-59 , - * / 小時 0-23 , - * / 日期 1-31 , - * ? / L W C 月份 1-12 或者 JAN-DEC , - * / 星期 1-7 或者 SUN-SAT , - * ? / L C # 年(可選) 留空, 1970-2099 , - * /
表達式 意義 "0 0 12 * * ?" 天天中午12點觸發 "0 15 10 ? * *" 天天上午10:15觸發 "0 15 10 * * ?" 天天上午10:15觸發 "0 15 10 * * ? *" 天天上午10:15觸發 "0 15 10 * * ? 2005" 2005年的天天上午10:15觸發 "0 * 14 * * ?" 在天天下午2點到下午2:59期間的每1分鐘觸發 "0 0/5 14 * * ?" 在天天下午2點到下午2:55期間的每5分鐘觸發 "0 0/5 14,18 * * ?" 在天天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發 "0 0-5 14 * * ?" 在天天下午2點到下午2:05期間的每1分鐘觸發 "0 10,44 14 ? 3 WED" 每一年三月的星期三的下午2:10和2:44觸發 "0 15 10 ? * MON-FRI" 週一至週五的上午10:15觸發 "0 15 10 15 * ?" 每個月15日上午10:15觸發 "0 15 10 L * ?" 每個月最後一日的上午10:15觸發 "0 15 10 ? * 6L" 每個月的最後一個星期五上午10:15觸發 "0 15 10 ? * 6L 2002-2005" 2002年至2005年的每個月的最後一個星期五上午10:15觸發 "0 15 10 ? * 6#3" 每個月的第三個星期五上午10:15觸發
特殊字符 意義
* 表示全部值;
? 表示未說明的值,即不關心它爲什麼值;
- 表示一個指定的範圍;
, 表示附加一個可能值;
/ 符號前表示開始時間,符號後表示每次遞增的值;
L("last") ("last") "L" 用在day-of-month字段意思是 "這個月最後一天";用在 day-of-week字段, 它簡單意思是 "7" or "SAT"。若是在day-of-week字段裏和數字聯合使用,它的意思就是 "這個月的最後一個星期幾" – 例如: "6L" means "這個月的最後一個星期五". 當咱們用「L」時,不指明一個列表值或者範圍是很重要的,否則的話,咱們會獲得一些意想不到的結果。
W("weekday") 只能用在day-of-month字段。用來描敘最接近指定天的工做日(週一到週五)。例如:在day-of-month字段用「15W」指「最接近這個月第15天的工做日」,即若是這個月第15天是週六,那麼觸發器將會在這個月第14天即週五觸發;若是這個月第15天是週日,那麼觸發器將會在這個月第16 天即週一觸發;若是這個月第15天是週二,那麼就在觸發器這天觸發。注意一點:這個用法只會在當前月計算值,不會越過當前月。「W」字符僅能在day- of-month指明一天,不能是一個範圍或列表。也能夠用「LW」來指定這個月的最後一個工做日。
# 只能用在day-of-week字段。用來指定這個月的第幾個周幾。例:在day-of-week字段用"6#3"指這個月第3個週五(6指週五,3指第3個)。若是指定的日期不存在,觸發器就不會觸發。
C 指和calendar聯繫後計算過的值。例:在day-of-month 字段用「5C」指在這個月第5天或以後包括calendar的第一天;在day-of-week字段用「1C」指在這週日或以後包括calendar的第一天。
在MONTH和Day Of Week字段裏對字母大小寫不敏感
定時從tb_account中查詢數據並插入到 e_sp_balance_zero
CREATE DEFINER=`dbremote`@`%` PROCEDURE `dbop_zeroBalance`() BEGIN Insert into e_sp_balance_zero(sp_id,insert_date,balance,create_time,`desc`) select spuserid,curdate(),balance,now(),CONCAT(curdate(),'零點時分的餘額狀況') from tb_account; END
最大的利處在於運算過程當中不須要將數據取出數據庫,會得到較高的性能,由於數據庫IO通道效率一貫不好,大量數據取出來很費時間。
但存儲過程的弊端會更多,存儲過程自己的運算性能其實不好,遠遠低於外部的java程序,而之因此用存儲過程,經常是由於個業務邏輯過於複雜難以用SQL描述,須要用存儲過程遍歷數據庫實現業務,這時的性能反而會差得多;另外,存儲過程須要編譯才能使用,修改算法時要dba的配合,形成安全性的威脅。因此,對於存儲過程,原則上是隻要性能還過得去,能不用則不用。或者大多數算法不要用,只有極個別涉及數據量巨大的業務採用。