iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL数据库中怎么实现定时任务
  • 784
分享到

MySQL数据库中怎么实现定时任务

2024-04-02 19:04:59 784人浏览 安东尼
摘要

今天就跟大家聊聊有关Mysql数据库中怎么实现定时任务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、事件概述在mysql 5.1中新增了一个特色

今天就跟大家聊聊有关Mysql数据库中怎么实现定时任务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

一、事件概述

mysql 5.1中新增了一个特色功能事件调度器(Event Scheduler),简称事件。

事件(event)是Mysql在相应的时刻调用的过程式数据库对象。一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的“事件调度器”。

事件和触发器类似,都是在某些事情发生的时候启动。当数据库上启动一条语句的时候,触发器就启动了,而事件是根据调度事件来启动的。由于他们彼此相似,所以事件也称为临时性触发器。事件取代了原先只能由操作系统的计划任务来执行的工作,而且MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:linux下的CRON或windows下的任务计划)只能精确到每分钟执行一次。

二、事件的优缺点

优点:一些对数据定时性操作不再依赖外部程序,而直接使用数据库本身提供的功能。可以实现每秒钟执行一个任务,这在一些对实时性要求较高的环境下就非常实用了。

缺点:定时触发,不可以调用。

三、事件调度器参数

事件由一个特定的线程来管理。启用事件调度器后,拥有SUPER权限的账户执行SHOW PROCESSLIST就可以看到这个线程了。

--查看事件是否开启。SHOW VARIABLES LIKE 'event_scheduler';SELECT @@event_scheduler;--全局开启事件调度器SET GLOBAL event_scheduler = ON;--全局关闭事件调度器SET GLOBAL event_scheduler = OFF;--永久开启事件调度器(在my.cnf配置文件中添加)#事件调度器启动状态event_scheduler = on

四、创建事件

一条create  event语句创建一个事件。每个事件由两个主要部分组成,第一部分是事件调度(eventschedule,表示事件何时启动以及按什么频率启动;

第二部分是事件动作(event  action),这是事件启动时执行的代码,事件的动作包含一条SQL语句,它可能是一个简单地insert或者update语句,也可以使一个存储过程或者

benin...end语句块,这两种情况允许我们执行多条SQL。

一个事件可以是活动(打开)的或停止(关闭)的,活动意味着事件调度器检查事件动作是否必须调用,停止意味着事件的声明存储在目录中,但调度器不会检查它是否应该调用。在一个事件创建之后,它立即变为活动的,一个活动的事件可以执行一次或者多次。

相关语法:

CREATE  [DEFINER = { user | CURRENT_USER }]   EVENT   [IF NOT EXISTS]   event_name   ON SCHEDULE schedule   [ON COMPLETION [NOT] PRESERVE]   [ENABLE | DISABLE | DISABLE ON SLAVE]   [COMMENT 'comment']   DO event_body;    schedule:   AT timestamp [+ INTERVAL interval] ...  | EVERY interval   [STARTS timestamp [+ INTERVAL interval] ...]   [ENDS timestamp [+ INTERVAL interval] ...]    interval:   quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |        WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |        DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}

说明:

MySQL数据库中怎么实现定时任务

MySQL数据库中怎么实现定时任务

五、事件(定时任务)管理

1. 查询事件

在MySQL中可以通过查询infORMation_schema.events表,查看已创建的事件。

--查看当前所在库的事件show events;--查看所有事件SELECT * FROM information_schema.events;

2. 修改事件

事件被创建之后,还可以使用ALTER EVENT语句修改其定义和相关属性

ALTER[DEFINER={user | CURRENT_USER}]EVENT [IF NOT EXISTS] event_nameON SCHEDULE schedule[ON COMPLETION [NOT] PRESERVE][ENABLE | DISABLE | DISABLE ON SLAVE][COMMENT 'comment']DO event_body;

3. 启动与关闭事件

ALTER EVENT语句可以让一个事件关闭或再次活动。

--启动事件。ALTER EVENT event_name ENABLE;--关闭事件。ALTER EVENT event_name DISABLE;

4. 删除事件

删除已经创建的事件可以使用DROP EVENT语句来实现。

DROP EVENT IF EXISTS event_name;

六、实例演示

1. 事件+sql

创建名称为event_t1的事件,用于每隔5秒钟向数据表t1(用户信息表)中插入一条数据。

-- 创建用户信息表CREATE TABLE IF NOT EXISTS t1( id INT AUTO_INCREMENT PRIMARY KEY COMMENT '用户编号', name VARCHAR(30) NOT NULL COMMENT '用户姓名', create_time TIMESTAMP COMMENT '创建时间') COMMENT = '用户信息表';-- 创建事件CREATE EVENT IF NOT EXISTS event_t1ON SCHEDULE EVERY 5 SECONDON COMPLETION PRESERVECOMMENT '新增用户信息定时任务'DO INSERT INTO t1(name,create_time) VALUES('hwb',NOW());

MySQL数据库中怎么实现定时任务

2. 事件+存储过程

--创建总表CREATE TABLE IF NOT EXISTS t_total( userNumber INT  COMMENT '用户数', createtime TIMESTAMP COMMENT '创建时间') COMMENT = '总表';--创建名称为t_total的存储过程,用于统计前面表插入的数量CREATE PROCEDURE t_total()BEGIN DECLARE n_total INT default 0; SELECT COUNT(*) INTO n_total FROM t1; INSERT INTO t_total (userNumber,createtime) VALUES(n_total,NOW());END;--创建名称为event_total的事件,用于在每天12点调用存储过程。CREATE EVENT IF NOT EXISTS event_totalON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 12 HOUR)ON COMPLETION PRESERVE ENABLEDO CALL t_total();

MySQL数据库中怎么实现定时任务

看完上述内容,你们对MySQL数据库中怎么实现定时任务有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网数据库频道,感谢大家的支持。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库中怎么实现定时任务

本文链接: https://www.lsjlt.com/news/57992.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL数据库中怎么实现定时任务
    今天就跟大家聊聊有关MySQL数据库中怎么实现定时任务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、事件概述在MySQL 5.1中新增了一个特色...
    99+
    2024-04-02
  • mysql中怎么实现定时任务
    今天就跟大家聊聊有关mysql中怎么实现定时任务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 定时任务 查看event是否开启: show v...
    99+
    2024-04-02
  • mysql中怎样实现定时任务
    今天就跟大家聊聊有关mysql中怎样实现定时任务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。mysql 5.1:Create event crm_...
    99+
    2024-04-02
  • oracle数据库定时任务怎么写
    oracle 数据库的定时任务,称为作业计划程序,可创建和管理定期运行命令或脚本的任务。创建任务的步骤包括:1. 使用 create job 语法创建作业;2. 使用 alter job...
    99+
    2024-04-08
    oracle
  • 使用datax实现增量同步mysql数据库数据(定时任务)
    使用datax来做数据全量同步很简单,增量同步该怎样做呢,接下来就一起试试吧 下载datax(前提CentOS已安装jdk等运行环境),解压(路径自定),使用centos7自带的python执行datax.py,运行自检 wget http...
    99+
    2023-09-22
    python json 开发语言 数据库
  • mysql数据库定时备份怎么实现
    有多种方法可以实现MySQL数据库的定时备份,以下是其中一种常用的方法: 使用crontab定时任务: 首先创建一个备份脚本,比...
    99+
    2024-04-12
    mysql
  • Swoole中怎么实现定时任务
    这篇文章主要介绍“Swoole中怎么实现定时任务”,在日常操作中,相信很多人在Swoole中怎么实现定时任务问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Swoole中怎么实现定时任务”的疑惑有所帮助!接下来...
    99+
    2023-07-05
  • Mysql数据库实现数据定时备份
    为了防止数据丢失,在进行软件交付时通常会要求对数据库进行定期备份。 测试使用mysqldump进行数据库备份。 mysqldump -h 192.168.248.138 -uroot -proot d...
    99+
    2023-09-02
    数据库 mysql sql 定时备份 crontab
  • MySQL数据库Event定时执行任务详解
    一、背景   由于项目的业务是不断往前跑的,所以难免数据库的表的量会越来越庞大,不断的挤占硬盘空间。即使再大的空间也支撑不起业务的增长,所以定期删除不必要的数据是很有必要的。在我们项目中由于不清理...
    99+
    2024-04-02
  • PHP实现数据库备份定时任务的方法
    随着互联网的快速发展,网站数据已经成为企业最重要的资产之一。然而不管是哪种类型的网站,难免会遇到数据丢失的问题。因此,数据库备份变得非常必要。本文将介绍一种使用PHP编写数据库备份的自动定时任务方法,既能保证数据的安全性,又能减轻管理员的工...
    99+
    2023-05-19
    PHP 定时任务 数据库备份
  • oracle数据库定时任务怎么写出来
    可以通过以下三种方法编写 oracle 数据库定时任务:使用 dbms_scheduler 包创建 scheduler 存储过程和作业。使用 oracle scheduler 服务创建凭...
    99+
    2024-04-18
    oracle
  • mysql数据库定时每天备份怎么实现
    实现MySQL数据库定时每天备份可以使用以下方法: 使用cron定时任务:在Linux系统上,可以使用cron定时任务来实现每天...
    99+
    2023-10-24
    mysql数据库
  • Java中怎么实现SpringBoot定时任务
    今天就跟大家聊聊有关Java中怎么实现SpringBoot定时任务,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. SpringBoot--任务:定时任务项目开发中经常需要执行一些...
    99+
    2023-06-20
  • Android中alarmmanager定时任务怎么实现
    在Android中,可以使用`AlarmManager`类来实现定时任务。下面是一个基本的步骤:1. 创建一个`PendingInt...
    99+
    2023-10-08
    Android
  • 怎么在java中实现定时任务
    这篇文章给大家介绍怎么在java中实现定时任务,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一.分类从实现的技术上来分类,目前主要有三种技术(或者说有三种产品):Java自带的java.util.Timer类,这个类允...
    99+
    2023-06-15
  • SpringBoot定时任务怎么实现
    这篇文章主要讲解了“SpringBoot定时任务怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot定时任务怎么实现”吧!SpringBoot定时任务主要由两个注解完成...
    99+
    2023-06-05
  • python怎么实现定时任务
    这篇文章主要介绍python怎么实现定时任务,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!用Python实现定时任务有些时候我们需要每隔一段时间就要执行一段程序,或者是往复循环执行某一个任务。比如博主在上篇文章讲的爬...
    99+
    2023-06-14
  • node怎么实现定时任务
    本教程操作环境:linux7.3系统、node18.4.0版、Dell G3电脑。node怎么实现定时任务node定时任务(node-schedule模块)实现一个每天凌晨十二点更新服务器上的git代码的功能koa2框架下的app.js文件...
    99+
    2022-11-22
    定时任务 node
  • Canal中怎么实现MySQL数据库实时数据同步
    这期内容当中小编将会给大家带来有关Canal中怎么实现MySQL数据库实时数据同步,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.1 canal介绍Canal是一个基于...
    99+
    2024-04-02
  • laravel定时任务怎么实现
    在 Laravel 中,可以使用 Artisan 命令来创建和管理定时任务。以下是如何实现定时任务的步骤: 创建定时任务类:首先,...
    99+
    2024-03-04
    laravel
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作