Mysql事件调度器(Event Scheduler)类似于定时器,可以在某一个时间点执行一个SQL语句或一个语句块(BEGIN ... END);或者每隔固定间隔重复执行。类似于Linux下的crontab,或Windows下的Task Scheduler。

 
一、事件调度器的配置
所有事件都是在事件调度线程(event scheduler thread)里面执行的;当提及事件调度器时,通常指该线程。如果用户有PROCESS权限,可以通过SHOW PROCESSLIST命令来查看该线程及其状态:

Mysql使用存储过程和Event事件定期删除数据

整个过程总共分为三步:

1. 写存储过程

2. 写Event事件

3. 把Event事件设置成Enable并打开事件任务

1. 存储过程

首先定义一个存储过程,del_data,传入一个int参数就是保留的log内容天数,过程的内容就是删除t_xxx表一周外的数据和删除t_log表的保留天数外的数据。

create procedure del_data(IN `date_inter` int)
begin
delete from t_xxx where date < date_sub(curdate(),interval 7 day);
delete from t_log where date < date_sub(curdate(),interval date_inter day);
end

2. 写Event事件

定义del_event,在Event事件中定义事件执行的开始事件和频率,事件设置成Enable,并且到点的时候执行del_data存储过程(传进去的天数是30天)。

create event del_event
on schedule
EVERY 1 day
STARTS '2014-01-01 03:00:00'
ON COMPLETION PRESERVE ENABLE
do call del_data(30)

还可以控制事件的开启个关闭:

关闭事件任务: alter event del_event ON COMPLETION PRESERVE DISABLE;
开户事件任务: alter event del_event ON COMPLETION PRESERVE ENABLE;

你也可以使用show events看看刚才新建的事件。

3. 打开事件任务

查看event是否开启: show variables like '%sche%';
将事件计划开启: set global event_scheduler = ON;

当然,你也可以把存储过程写在Event事件中,就是不太规范啦:

delimiter |

CREATE EVENT e_daily
ON SCHEDULE
EVERY 1 DAY
COMMENT 'Saves total number of sessions then clears the table each day'
DO
BEGIN
INSERT INTO site_activity.totals (time, total)
SELECT CURRENT_TIMESTAMP, COUNT(*)
FROM site_activity.sessions;
DELETE FROM site_activity.sessions;
END | delimiter ;

http://www.2cto.com/database/201402/278096.html

1.显示数据库中所有的存储过程

  1. show procedure status;

2.显示某个存储过程的详细信息(sp为存储过程名称)

  1. show create procedure sp;

3.显示当前库中所有表

  1. show tables;

4.显示某个表的建表语句(test为表名)

  1. show create table test;

5.删除存储过程(sp为存储过程名称)

  1. drop procedure if exists sp;

6.先建表

  1. --设置分隔符为双斜杠(//),默认为分号(;),由于存储过程中要用到分号,固将结束分隔符设置为双斜杠
  2. delimiter//
  3. DROP TABLE if exists test //
  4. CREATE TABLE test(id int(11) NULL) //

7.最简单的存储过程

  1. drop procedure if exists sp//
  2. CREATE PROCEDURE sp() select 1 //
  3. --调用存储过程
  4. call sp()//

8.带输入参数的存储过程

  1. drop procedure if exists sp1 //
  2. create procedure sp1(in p int)
  3. begin
  4. --声明一个int类型的变量
  5. declare v1 int;
  6. --将参数传给声明的变量,此步骤多余,可不要
  7. set v1 = p;
  8. insert into test(id) values(v1);
  9. end
  10. //
  11. --调用这个存储过程
  12. call sp1(1)//
  13. --去数据库查看调用之后的结果
  14. select * from test//

9.带输出参数的存储过程

  1. drop procedure if exists sp2 //
  2. create procedure sp2(out p int)
  3. begin
  4. select max(id) into p from test;
  5. end
  6. //
  7. --调用该存储过程,注意:输出参数必须是一个带@符号的变量
  8. call sp2(@pv)//

10.带输入和输出参数的存储过程

  1. drop procedure if exists sp3 //
  2. create procedure sp3(in p1 int , out p2 int)
  3. begin
  4. if p1 = 1 then
  5. --用@符号加变量名的方式定义一个变量,与declare类似
  6. set @v = 10;
  7. else
  8. set @v = 20;
  9. end if;
  10. --语句体内可以执行多条sql,但必须以分号分隔
  11. insert into test(id) values(@v);
  12. select max(id) into p2 from test;
  13. end
  14. //
  15. --调用该存储过程,注意:输入参数是一个值,而输出参数则必须是一个带@符号的变量
  16. call sp3(1,@ret)//
  17. select @ret//

11.既做输入又做输出参数的存储过程

    1. drop procedure if exists sp4 //
    2. create procedure sp4(inout p4 int)
    3. begin
    4. if p4 = 4 then
    5. set @pg = 400;
    6. else
    7. set @pg = 500;
    8. end if;
    9. select @pg;
    10. end//
    11. call sp4(@pp)//
    12. --这里需要先设置一个已赋值的变量,然后再作为参数传入
    13. set @pp = 4//
    14. call sp4(@pp)//

http://weidongke123-126-com.iteye.com/blog/1675375

mysql Event、存储过程、表命令的更多相关文章

  1. sql语句备份/导入 mysql数据库或表命令

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/qq1355541448/article/details/30049851

  2. MySQL中将数据库表名修改成大写的存储过程

    原文:MySQL中将数据库表名修改成大写的存储过程 MySQL中将数据库表名修改成大写的存储过程 创建存储过程的代码: DROP PROCEDURE IF EXISTS uppercaseTablen ...

  3. mysql详解常用命令操作,利用SQL语句创建数据表—增删改查

    关系型数据库的核心内容是 关系 即 二维表 MYSQL的启动和连接show variables; [所有的变量] 1服务端启动 查看服务状态 sudo /etc/init.d/mysql status ...

  4. MYSQL 使用存储过程批量更新表数据

    功能:实现将表result_good_city_dzl中的字段lat更新为表 result_good_city_lh中的lat,条件是两个表中的id一样 即: update result_good_c ...

  5. mybatis调用mysql的存储过程(procedure),实现查询操作(student表中的某个年级中的总人数 select (1) 或者 select (*))

    step1:在mysql cmd中新建存储过程: drop procedure if exists queryCountByGrade ; delimiter // -- 定义存储过程结束符号为// ...

  6. mysql的存储过程,函数,事件,权限,触发器,事务,锁,视图,导入导出

    1.创建过程 1.1 简单创建 -- 创建员工表 DROP TABLE IF EXISTS employee; CREATE TABLE employee( id int auto_increment ...

  7. MySQL数据库以及表的管理

    MySQL数据库以及表的管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 今天我们探讨的话题就是如何使用MySQL做开发,我们运维的主要工作不是去开发SQL的,但尽管如此,我们有 ...

  8. 高可用Mysql架构_Mysql主从复制、Mysql双主热备、Mysql双主双从、Mysql读写分离(Mycat中间件)、Mysql分库分表架构(Mycat中间件)的演变

    [Mysql主从复制]解决的问题数据分布:比如一共150台机器,分别往电信.网通.移动各放50台,这样无论在哪个网络访问都很快.其次按照地域,比如国内国外,北方南方,这样地域性访问解决了.负载均衡:M ...

  9. MySql创建存储过程,并使用事件定时调用

    一.使用命令行创建存储过程的步骤 :参数详情参考 https://www.mysqlzh.com/ 1.模板  delimiter $$ # 设置分隔符为 '$$' ,mysql默认的语句分隔符为 ' ...

随机推荐

  1. WEB 移动网站 手机点击 打电话 发短信

    原文地址: http://www.blesswe.com/portal.php?mod=view&aid=428 我们在手机浏览网页是希望用户看到手机号码点击就可以直接打电话或发短信,下面我们 ...

  2. Asp.Net 构架(Http Handler 介绍) - Part.2

    原文地址:http://www.cnblogs.com/JimmyZhang/archive/2007/09/15/894124.html 引言 在 Part.1 Http请求处理流程 一文中,我们了 ...

  3. c语言结构体5之匿名结构体

    注意: 1匿名结构体不会出现重合 重命名的情况 2有名结构体 名称不能相同 也就是不能重名 //匿名结构体不会出现重名的情况 struct //无名结构体 { ]; ]; int num; };//不 ...

  4. Annotation(四)——Struts2注解开发

    Hibernate和Spring框架的开发前边总结了,这次看一下流行的MVC流程框架Struts2的注解开发吧.Struts2主要解决了从JSP到Action上的流程管理,如何进行Uri和action ...

  5. java常用方法

    public static int byte2int(byte b) { int i = b & 0x07f; if (b < 0) { i |= 0x80; } return i; } ...

  6. 真实经纬度(gps)转成百度坐标的js方法

    转:http://www.360doc.com/content/16/0320/14/18636294_543805051.shtml 结果图: <!DOCTYPE html> <h ...

  7. socket用法以及tomcat静态动态页面的加载

    一.套接字的使用: 分为以下几步: 1.创建ServerSocket 2.接收客户端的连接 3.读取本地的test.html文件 4.构建数据输出通道 5.发送数据 6.关闭资源 代码参考: pack ...

  8. Android菜鸟的成长笔记(28)——Google官方对Andoird 2.x提供的ActionBar支持

    在Google官方Android设计指南中(链接:http://www.apkbus.com/design/get-started/ui-overview.html)有一个新特性就是自我标识,也就是宣 ...

  9. HDU 4907 Task schedule

    对于询问q 假设q不存在直接输出q 否则输出后面第一个不存在的数 从2*10^5到1遍历一边ac #include<bits/stdc++.h> using namespace std; ...

  10. 用递归翻转一个栈 Reverse a stack using recursion

    明白递归语句之前的语句都是顺序运行,而递归语句之后的语句都是逆序运行 package recursion; import java.util.Stack; public class Reverse_a ...