mysql - java Web 计时器
高洛峰
高洛峰 2017-04-17 13:39:01
[Java讨论组]

我用jsp+servlet+mysql搞了一个众筹网站。当一个项目发起后,它有一个众筹时间,过了这个时间,项目就会从众筹状态转到另一个状态,当然,这需要在数据库中去操作。那么,如何设计一个计时器,在规定时间将触发,去更改相应的数据库表呢?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(5)
巴扎黑

Spring+quartz 做定时任务

阿神

楼上提到java.util.Timer

如果要使用,题主需要注意这种情况

public class BadCaseOfTimer {

    public static void main(String[] args) {
        Timer timer = new Timer();

        timer.schedule(new ThrowTask(),1);
        timer.schedule(new ThrowTask(),1);


    }

    static class ThrowTask extends TimerTask{

        @Override
        public void run() {
            System.out.println("runnin.."+System.currentTimeMillis());
            throw new RuntimeException();
        }
    }

}
巴扎黑

可以用java.util.Timer类的schedule方法

大家讲道理

有一个问题
时间到了以后,从一个状态转到另一个状态,除了改变这个字段的值以外,还有其它需要触发进行的操作么?
如果没有,很可能你不需要一个定时任务。

只需要在数据库中记录项目发起时间和期限,在需要判断状态的时候根据这两个值和当前时间,决定项目的状态。
类似于你的网站里记录用户的生日信息,在页面显示用户年龄。我想没有人会真的在数据库保存年龄然后每天刷新的。

阿神

不需要定时任务,只要设置开始结束时间,在所需的业务逻辑处判断即可:
1、筛选正在众筹的列表,sql添加条件:

startTime > now() AND endTime < now()

2、区分状态,在model中通过判断时间来转义称状态:

public class Item{
    private Date startTime;
    private Date endTime;
    
    public String getStatus(){
        if(startTime != null && endTime != null){
            Date now = new Date();
            if(now.after(startTime) && now.before(endTime)){
                return "正在众筹中";
            }else if(now.before(startTime)){
                return "还未开始";
            }else if(now.after(endTime)){
                return "已结束";
            }
        }
        return "";
    }
    ...
}
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号