一、常用数据频度维护
对于系统使用度较高的数据,客户在查看时希望这些数据最好先出现,此时需要为其添加排序规则。在进行排序时,使用次数成为排序的依据。因此需要设置一个字段用来描述某种数据的使用次数,也就是所谓的使用频度。
本系统中,商品数据是整体数据流的核心数据,为商品数据添加频度字段。
该字段的值默认为0,每使用一次,将其值自增一。但是如果每次使用都修改该表的对应字段,操作量无疑是巨大的,并且还牵扯到数据库操作的隔离级问题,需要防止并发带来的错误操作。
系统中经常会出现此类任务,即需要修改某些数据的值,但是此数据并不需要具有很强的即时性。只需要在某一个特定时刻,将该值修改即可。
基于上述分析,需要一种机制保障,在特定时间点,将对应商品的使用次数修改为当前已使用的总次数即可。最终数据排序时,以该字段作为排序依据即可。
上述问题需要完成两个任务即可
规定时间内循环执行某任务
执行特殊的SQL语句,完成修改使用次数字段的任务
二、Spring定时作业调度
Spring提供了定时器任务,用于在规定时间执行对应的任务。
1.定义定时作业任务Bean,及其作业任务对应的操作
2.将其配置为Spring管理的Bean
3.定义作业任务
4.定义作业任务的执行时间周期
5.设置该任务加入定时任务
6.修改执行的时间周期值,参看:资源/定时调度Quartz/Cron表达式.txt
7.源码
三、常用数据频度维护
使用Spring数据频度调度维护,配置需改数据操作,完成商品使用量频度维护
1.定义维护商品使用频度的SQL语句,执行并验证执行效果
2.将上述任务转化为定时任务方法
注入对应的数据层Bean,并开启事务
3.设置该任务的执行周期
四、库存预警功能
库存预警功能是对库存商品数量进行报警的一种机制。当库存商品数量高于或低于指定的预警数量时,产生报警信息。
报警信息可以是如下方案之一
发邮件
发短信
给手机发送消息
发出警报消息(ERP系统内发送给主管:主管再将该任务派发到人员:实现方式ServletContext范围内的数据共享,创建集合(必须是多线程安全的)页面设计定时器定时获取该集合数据,每隔一段时间发送AJAX请求,获取预警信息
报警操作必须时刻监控库存商品的数量。如果到达报警临界值,进行指定方式的信息报警。此处使用Email形式进行报警。
1.设置报警定时器任务,当库存商品总数量低于最低值或高于最高值时,发送Email到仓库管理员,进行预警报警。
2.设置库存预警定时作业调度任务
3.测试定时作业是否成功
4.获取引发预警信息的数据
对库存明细数据进行分组统计求和,如果数量超出对应商品的库存预警值,将该商品加入库存预警信息
5.获取数据后判断是否需要发送库存预计信息
五、Spring整合JavaMail
Spring提供对JavaMail的整合技术,配置JavaMail发送器为Spring管理的Bean,实现Spring管理资源的机制。
1.配置Spring管理的JavaMail发送器对象
2.设置发送邮件相关内容
3.设置发送邮件的消息内容
4.发送邮件
领取专属 10元无门槛券
私享最新 技术干货