有照片,细节待补充
1.ShardingContext,logger里的几个参数,sql里的涉及。
implements SimpleJob后会重写execute(ShardingContext shardingContext)方法,在此方法中处理定时任务的逻辑。
logger中有几个参数:(待补充)
且用了String.format...%s...%s...这样的写法,是slf4j.logger自带的?
查询的map也会加入两个相关参数……
在sql里面这两个参数的用法……
2.分片每次处理的最大交易笔数要设置得比分片每次查询数量少?项目里分别是60和100
3.这里的分批处理和用PageHelper的分页处理操作不一样。
这里是先查出整个list,再对list进行处理。for循环之前初始化单分片交易数,for循环内处理每条数据,每处理一条,单分片交易数自增1,注意是++i 而不是i++。
注意此处dao传入的0和100(分片每次查询的数据量)两个参数是分别作为offset和pageSize传入的,实际在sql中并没有用到这两个参数,猜测是在daoImpl中myBatis框架实现的分页。
4.两个地方用到状态机,实体类里增加了原交易状态,原重试次数的字段,sql里也加了相关条件。目的都是为了防止重复任务。一次是更新交易状态,一次是更新重试次数。
5.定时任务implements SimpleJob