看到楼下各位兄弟的批评指正后,确实对我很有启发,任务如果都以配置的形式出现,在项目中是很利于维护的,所以,稍作修改,呵呵。

首先要做QuartzJob定时任务类了,这个类要实现的是Job接口,然后重写execute方法,方法中就是执行你具体要做的事情了。不过首先需要一个配置文件,里面定义了一些参数,是Quartz的一些配置。配置文件如下

Java代码
  1. #============================================================================
  2. # Configure Main Scheduler Properties
  3. #============================================================================
  4. org.quartz.scheduler.instanceName = QuartzScheduler
  5. org.quartz.scheduler.instanceId = AUTO
  6. #============================================================================
  7. # Configure ThreadPool
  8. #============================================================================
  9. org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
  10. org.quartz.threadPool.threadCount = 3
  11. org.quartz.threadPool.threadPriority = 5
  12. #===============================================================
  13. #Configure JobStore
  14. #===============================================================
  15. org.quartz.jobStore.misfireThreshold = 60000
  16. org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
  17. #============================================================================
  18. # Configure Plugins
  19. #============================================================================
  20. #org.quartz.plugin.triggHistory.class = org.quartz.plugins.history.LoggingJobHistoryPlugin
  21. org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin
  22. org.quartz.plugin.jobInitializer.fileName = conf/quartz_jobs.xml
  23. org.quartz.plugin.jobInitializer.overWriteExistingJobs = true
  24. org.quartz.plugin.jobInitializer.failOnFileNotFound = true
  25. org.quartz.plugin.jobInitializer.scanInterval = 60

即使做成配置,这个类也必须要有,一定会有个Job类,专门做数据分析,有的朋友说配置文件搞定所有,不现实,
好了,这就是配置文件,接下来我们就要做这个计划类了,这个类执行的是去源数据库中查询数据,并插入目标数据库中,并且不允许有重复。代码如下

Java代码
  1. package com.bj58.job.servlet;
  2. import java.sql.Connection;
  3. import java.sql.PreparedStatement;
  4. import java.sql.ResultSet;
  5. import java.sql.SQLException;
  6. import org.apache.commons.logging.Log;
  7. import org.apache.commons.logging.LogFactory;
  8. import org.quartz.Job;
  9. import org.quartz.JobExecutionContext;
  10. import org.quartz.JobExecutionException;
  11. import com.bj58.job.utils.ConnectionFactory_DB_dest;
  12. import com.bj58.job.utils.ConnectionFactory_DB_src;
  13. /**
  14. * 定时任务类
  15. * @author zhangwan@58.com
  16. * Jun 8, 2010
  17. *
  18. */
  19. public class QuartzJob implements Job {
  20. private static final Log log = LogFactory.getLog(Job.class);
  21. private static final String findSql_src = "select PortalId from t_portalinfo";
  22. private static final String findSql_dest = "select userId from t_user";
  23. private static final String insertSql_dest = "insert into t_user(userId) values (?)";
  24. /**
  25. * 执行任务方法
  26. */
  27. @Override
  28. public void execute(JobExecutionContext context) throws JobExecutionException {
  29. Connection conn_db_src = ConnectionFactory_DB_src.getConnection();
  30. Connection conn_db_dest = ConnectionFactory_DB_dest.getConnection();
  31. PreparedStatement pstmt_src = null;
  32. PreparedStatement pstmt_dest = null;
  33. ResultSet rs_src = null;
  34. ResultSet rs_dest = null;
  35. try {
  36. pstmt_src = conn_db_src.prepareStatement(findSql_src);
  37. rs_src = pstmt_src.executeQuery();
  38. pstmt_dest = conn_db_dest.prepareStatement(findSql_dest);
  39. rs_dest = pstmt_dest.executeQuery();
  40. pstmt_dest = conn_db_dest.prepareStatement(insertSql_dest);
  41. while(rs_dest.next()) { //第二次或第n次入库,第一次入库的话rs_dest没有结果,所以此段操作都不执行
  42. String userId = rs_dest.getString(1);
  43. while (rs_src.next()) {
  44. String protalId = rs_src.getString(1);
  45. if(userId.equals(protalId)) { //如果两个结果相同,则不进行入库
  46. break;
  47. } else {
  48. pstmt_dest.setString(1, protalId);
  49. pstmt_dest.execute();
  50. }
  51. }
  52. }
  53. while (rs_src.next()) { //如果是第一次入库
  54. String protalId = rs_src.getString(1);
  55. pstmt_dest.setString(1, protalId);
  56. pstmt_dest.execute();
  57. }
  58. log.info("存储数据...");
  59. } catch (SQLException e) {
  60. log.info("存储数据出现异常...");
  61. e.printStackTrace();
  62. } finally {
  63. ConnectionFactory_DB_dest.free(rs_dest, pstmt_dest, conn_db_dest);
  64. ConnectionFactory_DB_src.free(rs_src, pstmt_src, conn_db_src);
  65. log.info("数据库连接已经关闭...");
  66. }
  67. }
  68. }

这里一次性查出了源数据库中所有字段,因为源数据库表中的数据最多不会超过10000条,我在做测试的时候,在本机上发现一次查询10W条也不会出现结果集溢出情况,所以这里就忽略这个问题了。

然后需要这么个配置文件quartz_jobs.xml,内容如下

Java代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <quartz>
  3. <job>
  4. <job-detail>
  5. <name>PortalInfoJob</name>
  6. <group>PortalInfo</group>
  7. <job-class>com.bj58.portalcrm.web.job.PortalInfoJob</job-class>
  8. </job-detail>
  9. <trigger>
  10. <cron>
  11. <name>PORTALINFO</name>
  12. <job-name>PortalInfoJob</job-name>
  13. <job-group>PortalInfo</job-group>
  14. <cron-expression>0 0 1 * * ?</cron-expression>
  15. </cron>
  16. </trigger>
  17. </job>
  18. </quartz>

ok,最后就是web.xml文件配置一下,Quartz提供了个初始化的Servlet,呵呵,内容如下

Java代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app version="2.4"
  3. xmlns="http://java.sun.com/xml/ns/j2ee"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  5. xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
  6. http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
  7. <welcome-file-list>
  8. <welcome-file>index.jsp</welcome-file>
  9. </welcome-file-list>
  10. <!-- Quartz配置计划 -->
  11. <servlet>
  12. <servlet-name>QuartzInitializer</servlet-name>
  13. <servlet-class>org.quartz.ee.servlet.QuartzInitializerServlet</servlet-class>
  14. <load-on-startup>1</load-on-startup>
  15. <init-param>
  16. <param-name>config-file</param-name>
  17. <param-value>/quartz.properties</param-value>
  18. </init-param>
  19. <init-param>
  20. <param-name>shutdown-on-unload</param-name>
  21. <param-value>true</param-value>
  22. </init-param>
  23. </servlet>
  24. </web-app>

这样就搞定了,

企业定时任务调度器Quartz,定时查询数据库(这里还需要继续做研究)相关推荐

  1. Spring整合定时任务调度框架Quartz实

    Spring整合定时任务调度框架Quartz实战 定时的任务处理在程序开发中应用的相当普遍,之前一直使用JDK的Timer类库来做任务调度功能不是很方便,因为它不能像cron服务那样可以指定具体年.月 ...

  2. 使用Arduino开发ESP32(07):系统时间和定时任务调度器Ticker

    文章目录 目的 系统时间及应用 定时任务调度器Ticker 使用步骤 常用方法 使用事例 事例一 事例二 事例三 总结 目的 开发中经常会用到时间相关操作,主要就是用到系统时间.延时操作.定时任务调度 ...

  3. 一文揭秘定时任务调度框架quartz

    之前写过quartz或者引用过quartz的一些文章,有很多人给我发消息问quartz的相关问题, quartz 报错:java.lang.classNotFoundException quartz源 ...

  4. 分布式定时任务调度框架Quartz

    文章目录 一.Quartz引言 二.Quartz使用 2.1 导入依赖 2.2 定义Job 2.3 API测试 2.3.1 细节 2.4 配置 2.5 核心类说明 三.Trigger触发器 3.1 S ...

  5. quartz框架_定时任务调度框架Quartz

    最近需要写一个每天定点自动执行的定时任务,对于以前自己写小项目,可能会选择java自带的Timer类,但是对于公司中的项目,Timer类实现定时任务只能有一个后台线程执行任务,并且只能让程序按照某个频 ...

  6. windows 服务实现定时任务调度(Quartz.Net)

    我们通常在一些情况下需要软件具有一个自动执行某些任务的功能,但是又不希望直接启动软件,或者每次都要手动的来启动软件,这时我们可可以考虑到windows服务了. 首先创建一个windows服务项目(详细 ...

  7. 从零开始的ESP8266探索(11)-定时任务调度器Ticker使用演示

    文章目录 目的 使用演示 基本使用1 基本使用2 动态设置和参数传递 停止和重启任务 注意事项 总结 目的 Arduino for esp8266属于无操作系统环境,对于开发多任务的复杂应用还是比较麻 ...

  8. Java 定时任务调度工具 Quartz(Part 2)

    2019独角兽企业重金招聘Python工程师标准>>> 一.浅谈Job和JobDetail 1.Job接口:实现业务逻辑的任务接口,execute方法中实现具体逻辑(类似与Timer ...

  9. 一行代码完成定时任务调度,基于Quartz的UI可视化操作组件 GZY.Quartz.MUI

    前言 之前发布过第一个版本,有兴趣的可以去看看: NET Core 基于Quartz的UI可视化操作组件 GZY.Quartz.MUI 简介 GitHub开源地址:l2999019/GZY.Quart ...

最新文章

  1. html img调用js,html调用js变量 如何在html中输出js文件中的变量
  2. C++ algorithm的sort函数总结
  3. linux手动释放内存的方法
  4. 用MODELLER构建好模型后对loop区域进行自动的优化过程
  5. 脑机互动可提高行动能力
  6. mysql duplicateentry_[MySQL]mysqldump出来数据再导入回去,为什么会出现Duplicate entry?...
  7. 计算机基础课程在线教学授课方案,《计算机基础》课程分层次模块化教学实施方案...
  8. mysql增加布尔字段_JDBC对MySQL数据库布尔字段的操作方法
  9. java面试宝典2019_Java面试宝典2019完整版.doc
  10. SQL Server-流程控制 2,If...Else 语句
  11. C# 静态类的构造函数
  12. java有常函数_Java开发笔记(十一)常见的数学函数
  13. 小例子:在 ECharts 中实现日历图
  14. ROS2 Galactic nav2 使用自己的行为树插件
  15. 正在启动文档服务器,正在启动远程服务器
  16. java 监听udp_Java实现Udp网络编程
  17. Liquibase修改表字段
  18. 10年测试经验的性能测试工程师简历模板你见过吗?
  19. 为NodePad++添加CSS格式化功能
  20. leetcode845. 数组中的最长山脉

热门文章

  1. 【Python】集合类型产生KeyError异常原因及数据去重
  2. wxWidgets:wxCalendarCtrl类用法
  3. boost::mpl::less相关的测试程序
  4. boost::mp11::mp_transform_front相关用法的测试程序
  5. boost::mp11::mp_all相关用法的测试程序
  6. boost::math模块计算贝塞尔函数的零点的测试程序
  7. boost::hof::implicit用法的测试程序
  8. ITK:将BinaryMorphologicalClosingFilter应用于给定LabelMap的一个LabelObject
  9. DCMTK:测试DcmSCP和DcmSCU类
  10. VTK:PolyData之ImplicitSelectionLoop