说明:
(1)本篇博客的内容说明:利用Spring-Task模块,实现对所有图书【更新评分、评价人数】的功能;
(2)本篇博客的几个点:
● Mybatis-Plus可以帮助我们生成SQL语句;对于基本的增删改查,Mybatis-Plus是OK的;但是,对于复杂的SQL语句,Mybatis-Plus就比较吃力了;又因为,Mybatis-Plus只是扩展了Mybatis,其并没有修改Mybatis的任何内容;所以,我们在这儿,依旧可以使用Mybatis的内容;自然,这儿需要遵循Mybatis的开发规范,该对应的要对应好;
● 本篇博客的演示了Spring Task的基本使用;这是本篇博客的重点;
● 本篇博客的基本逻辑是:【分析业务逻辑,得到底层SQL】→【根据业务逻辑,编写业务代码】→【创建实现定时任务的类,调用业务逻辑代码,设置定时任务】;
目录
2.在BookMapper接口中,定义操作底层数据库,实现【更新评分、评价人数】的方法:updateEvaluation()方法;
3.在book.xml中,编写【更新评分、评价人数】的SQL;
4.在BookService接口中,定义【更新评分、评价人数】的方法:updateEvaluation()方法;(PS:Service中的可以起其他名字,无需和Mapper中的保持一致)
5.在BookServiceImpl实现类中,去实现【更新评分、评价人数】的方法:updateEvaluation()方法;
三:【Spring-Task】定时任务模块:在本项目上的应用;
2.在applicationContext.xml配置文件中,配置:去开始Spring Task定时任务注解模式;
3.创建task包,创建ComputeTask类:调用Service中的逻辑,设置定时任务;
一:【Spring-Task】定时任务模块,简介;
1.定时任务,简介;
定时任务概念:
我们想在 [几点几分几秒] 或者 [一个固定的时间间隔内] ,执行Java中的某一段代码;
定时任务是一种非常常见的应用场景:
比如,开发一个闹钟应用,设置其每天早上6:30时,自动播放闹铃,此时就是定时任务;
再比如,金融业中:银行每天需要根据当天的业务情况,生成数据统计报表;又因为,银行每天的业务量可能百万千万,数据量如此庞大,计 算这些业务,生成统计报表,是需要花费一定的时间;所以,我们不能在需要统计报表的时,即时先算;为此,银行就提出了一种延时处理的方案:通常在凌晨2:00-4:00,由银行的服务器自动执行处理数据的任务(这在银行的专业术语中,被称为日终处理),生成统计报表;第二天,当需要查看昨天的业务的统计报表时,只需要直接读取昨晚生成的数据就行了,而不需要现算;那么,如果保证在每天的凌晨2:00-4:00,去执行统计任务呐?其底层就是通过一些定时任务来处理的;
2.Spring-Task定时任务模块;
3.Cron表达式;
说明:
(1)Cron表达式,不是Java独有的技术;
(2)Cron表达式,是一个最多7位的字符串;这7位,分别对应秒、分、小时、日、月、星期、年;
(3)其中,第7位年,可以省略;日和星期是互斥的,即,写了日,星期就只能是?;写了星期,日就只能是?;(如果星期哪儿是?,就表示忽略星期)
(4)如上图中的第一个例子:表示:在任意年的、任意月、任意日、任意小时、任意分、0的时候,执行一次任务;;;;其实,也就是每分钟执行一次任务;
(5)上图的第二个例子:表示:在2000年、任意月、任意日、任意小时、每小时的前五分钟、第0和第30秒,执行任务;(这儿可以看到,我们可以【0,30】这样写,来指定分散的时间点)
(6)上图的第三个例子:表示:在任意年、任意月、星期三、第9-18小时、第0分、第0秒,执行任务;;;;其实,也就是每周三,上午9点到下午6点,整点的时候,执行任务;(这儿可以看到,当我们写了星期,就不能写日了;)
二:编写【更新评分、评价人数】的逻辑代码;
0.情况说明;
在前面,会员可以对图书进行评价;
那么,在新增评分的时候,需要重新计算一下该图书的评分;
……………………………………………………
此时,我们就可以使用【Spring-Task】&#