通过MySQL工作台向用户发送电子邮件



我现在使用MySQL工作台和NetBeans IDE在Linux Ubuntu上工作,使用Java EE开发web应用程序。

现在我需要开发一个功能,允许每个用户每周更新他们的数据,并检查数据是否每周更新。

如果数据在一周的最后一天没有被插入或更新到MySQL工作台,它将发送一个电子邮件通知用户更新数据。

  1. 如何实现?
  2. 需要使用哪些工具?MySQL工作台还是Netbean IDE?
  3. 是什么代码或任何教程来指导?

谢谢。

您有几种方法可以做到这一点。我认为你想做计划任务。

第一种方法是在java code中制作。用@WebListenerThreads。它是纯java库。你也可以使用Quartz Schedular,但我更喜欢java自己的库。

MyTaskScheduler.class

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.annotation.WebListener;
@WebListener
public class MyTaskScheduler implements ServletContextListener {
    private ScheduledExecutorService scheduler;
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        scheduler = Executors.newSingleThreadScheduledExecutor();
        scheduler.scheduleWithFixedDelay(new MyRunnable (), 0, 10, TimeUnit.SECONDS); // Here you can change timeOut and delay.
    }
    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        scheduler.shutdownNow();
    }
}

MyRunnable.class

public class MyRunnable implements Runnable {
    @Override
    public void run() {
        System.out.println("Runnable RUN");
    }
}

第二种方法是创建SimpleJavaApplication并使用操作系统的特性。

Windows

你可以使用taskschedule: Windows Task Scheduler using guide

Linux

你可以使用CronTab: CronTab using guide

您必须为任何时间段创建任务以运行此simpleApplication。

我必须注意到。我从不使用CronTab。我在Google中找到了Windows Task Scheduler的CronTab替代品

相关内容

  • 没有找到相关文章