赞
踩
要使用@Scheduled注解,首先需要在启动类添加@EnableScheduling,启用Spring的计划任务执行功能,这样可以在容器中的任何Spring管理的bean上检测@Scheduled注解,执行计划任务
比如
@Scheduled(cron = “0 0 0 * * ?”)
表示每天的凌晨零点开始定时执行任务。
从左到右用空格隔开分别是:秒 分 时 日 月 周 年(可省略)
第一个位置:Seconds 秒:区间 0-59 秒,代表一分钟内的秒数。
第二个位置:Minutes 分:区间 0-59 分,代表一小时内的分钟数。
第三个位置:Hours 时:区间 0-23 时,代表一天中的小时数。
第四个位置:Day of month 日:区间 1-31 (?根据每月有多少天来),代表一月中的多少号。
第五个位置:Month 月:区间 1-12 ,代表一年中的月份。
第六个位置:Day of week 周:区间 1-7或者英文星期的缩写,代表星期几。
第七个位置:Year 年:区间1970-2099,代表具体年份,一般不用,可以不写。
描述:写在cron表达式的标识符位置用于表达特定意义的字符 阿拉伯数字:数值,出现在标识符位置的数字代表对应值 * :通配,语义相当于每… 比如第五个位置的 *就表示每月都会执行(相当于1-12) ? :忽略,语义相当于不管… 比如第六个位置的?就表示不管当前是周几就会执行。至于为什么会有这种用法,我觉得应该是因为它和其他的字符可能会冲突。如果用*的话表示周一到周日都会执行,此时其他语义就不明确了,所以如果用不上星期的话一般给它用一个?表示 not care。 / :间隔,语义相当于每隔… 比如例2中的第三个位置的2/5就表示从2点开始每隔五小时 - :区间,语义相当于第…到…的每… 比如例2中的第二个位置的15-20就表示第15分钟到20分钟之间的每分钟 , :枚举,语义相当于第…和… 比如例2中的第一个位置的15,20,40就表示第15秒、20秒和40秒 L :最后(last),语义相当于最后一个 比如例2中的第四个位置的L就表示最后一天 W :工作日,字面意思,就是工作日 比如例3中的第四个位置的15W表示15号附近最近的工作日,如果15号刚好是工作日那就15号触发,如果15号是周六那就14号触发,如果15号是周日那就16号触发。前面不带数字就是所有匹配的工作日。 # :周定位,语义相当于每月的第几个周几 比如例4中的第六个位置的2#3就表示第三个周一。
@Component @EnableScheduling @Slf4j public class ScheduleTaskDeleteWaterquality { @Autowired private DataMapper DataMapper; @Scheduled(cron = "0 0 0 * * ? ") public void deleteDataInfo() { //删除3天前的数据 Date now=new Date(); String deleteDate=getDeleteDate(now,3); try{ DataMapper.deleteByDate(deleteDate); }catch (Exception e){ log.error("删除3天前的数据失败!"+e.getMessage()); } } //获取需要删除的时间 public static String getDeleteDate(Date now,int days){ //Calendar获得日期比较方标 getInstance创建static静态实例, Calendar calendar = Calendar.getInstance(); calendar.setTime(now); calendar.add(calendar.DATE, -days); Date delete=calendar.getTime(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); String dateString=sdf.format(delete); return dateString; } }
<!--删除3天前的挂号信息数据-->
<delete id="deleteByDate">
delete from patientRegister
where REGISTER_TIME like CONCAT(CONCAT('%',#{deleteDate,jdbcType=CHAR}),'%')
</delete>
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。