java定时执行

我们在项目中,经常会碰到这样一种需求,就是让某个程序在某个固定的时间去运行,比如定时备份操作。在Java的J2SE的API中可以很容易做到这一点。
让我们需要定时执行的类继承自java.util.TimerTask中的TimerTask类,把需要执行的方法放入run方法中:
1  import java.util.TimerTask;
2 
3  public  class MyTimerTask  extends TimerTask {
4 
5 @Override
6  public  void run() {
7 System.out.println("备份程序运行……");
8 }
9 
10 }
11
然后我们是java.util.Timer类来执行这个方法,测试类:
1  import java.util.Timer;
2 
3  public  class Test {
4 
5  public  static  void main(String[] args) {
6 Timer timer =  new Timer();
7 timer.schedule( new MyTimerTask(), 1000);
8 
9 }
10 
11 }
12
我们看到控制台输出:
备份程序运行……
那么我们想让这个程序每隔五秒钟运行一次呢,可以这样来做:
1 timer.schedule( new MyTimerTask(),0,5000);
我们传入的第二个参数是方法首次执行时间,第三个参数是方法执行的间隔时间,我们可以在控制台看到:
备份程序运行……
备份程序运行……
备份程序运行……
备份程序运行……
当然我们也可以使用Date来实现定时操作:
1 Timer timer =  new Timer();
2 Date date=  new Date(107,05,21,00,01,10);
3   timer.schedule( new  MyTimerTask(),date, 5000 ); 

以下是Java定时执行存储过程的示例代码: ```java import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; public class ScheduledTask { private static final String DB_URL = "jdbc:mysql://localhost:3306/test"; private static final String USER = "root"; private static final String PASSWORD = "123456"; private static final String CALL_PROCEDURE_SQL = "{call procedure_name()}"; public static void main(String[] args) { ScheduledExecutorService executorService = Executors.newScheduledThreadPool(1); executorService.scheduleAtFixedRate(() -> { Connection conn = null; CallableStatement stmt = null; try { conn = DriverManager.getConnection(DB_URL, USER, PASSWORD); stmt = conn.prepareCall(CALL_PROCEDURE_SQL); stmt.execute(); } catch (SQLException e) { // 处理异常 } finally { try { if (stmt != null) { stmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { // 处理异常 } } }, 0, 1, TimeUnit.HOURS); } } ``` 该示例代码使用了Java的ScheduledExecutorService类来定时执行存储过程。在main方法中,我们创建了一个ScheduledExecutorService实例,并使用scheduleAtFixedRate方法来定时执行一个Runnable任务。在该任务中,我们获取数据库连接,准备调用存储过程的CallableStatement对象,并执行该对象的execute方法来执行存储过程。最后,我们在finally块中关闭了CallableStatement和Connection对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值