mysql Event、存储过程、表命令
Mysql事件调度器(Event Scheduler)类似于定时器,可以在某一个时间点执行一个SQL语句或一个语句块(BEGIN ... END);或者每隔固定间隔重复执行。类似于Linux下的crontab,或Windows下的Task Scheduler。
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.显示数据库中所有的存储过程
- show procedure status;
2.显示某个存储过程的详细信息(sp为存储过程名称)
- show create procedure sp;
3.显示当前库中所有表
- show tables;
4.显示某个表的建表语句(test为表名)
- show create table test;
5.删除存储过程(sp为存储过程名称)
- drop procedure if exists sp;
6.先建表
- --设置分隔符为双斜杠(//),默认为分号(;),由于存储过程中要用到分号,固将结束分隔符设置为双斜杠
- delimiter//
- DROP TABLE if exists test //
- CREATE TABLE test(id int(11) NULL) //
7.最简单的存储过程
- drop procedure if exists sp//
- CREATE PROCEDURE sp() select 1 //
- --调用存储过程
- call sp()//
8.带输入参数的存储过程
- drop procedure if exists sp1 //
- create procedure sp1(in p int)
- begin
- --声明一个int类型的变量
- declare v1 int;
- --将参数传给声明的变量,此步骤多余,可不要
- set v1 = p;
- insert into test(id) values(v1);
- end
- //
- --调用这个存储过程
- call sp1(1)//
- --去数据库查看调用之后的结果
- select * from test//
9.带输出参数的存储过程
- drop procedure if exists sp2 //
- create procedure sp2(out p int)
- begin
- select max(id) into p from test;
- end
- //
- --调用该存储过程,注意:输出参数必须是一个带@符号的变量
- call sp2(@pv)//
10.带输入和输出参数的存储过程
- drop procedure if exists sp3 //
- create procedure sp3(in p1 int , out p2 int)
- begin
- if p1 = 1 then
- --用@符号加变量名的方式定义一个变量,与declare类似
- set @v = 10;
- else
- set @v = 20;
- end if;
- --语句体内可以执行多条sql,但必须以分号分隔
- insert into test(id) values(@v);
- select max(id) into p2 from test;
- end
- //
- --调用该存储过程,注意:输入参数是一个值,而输出参数则必须是一个带@符号的变量
- call sp3(1,@ret)//
- select @ret//
11.既做输入又做输出参数的存储过程
- drop procedure if exists sp4 //
- create procedure sp4(inout p4 int)
- begin
- if p4 = 4 then
- set @pg = 400;
- else
- set @pg = 500;
- end if;
- select @pg;
- end//
- call sp4(@pp)//
- --这里需要先设置一个已赋值的变量,然后再作为参数传入
- set @pp = 4//
- call sp4(@pp)//
http://weidongke123-126-com.iteye.com/blog/1675375
mysql Event、存储过程、表命令的更多相关文章
- sql语句备份/导入 mysql数据库或表命令
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/qq1355541448/article/details/30049851
- MySQL中将数据库表名修改成大写的存储过程
原文:MySQL中将数据库表名修改成大写的存储过程 MySQL中将数据库表名修改成大写的存储过程 创建存储过程的代码: DROP PROCEDURE IF EXISTS uppercaseTablen ...
- mysql详解常用命令操作,利用SQL语句创建数据表—增删改查
关系型数据库的核心内容是 关系 即 二维表 MYSQL的启动和连接show variables; [所有的变量] 1服务端启动 查看服务状态 sudo /etc/init.d/mysql status ...
- MYSQL 使用存储过程批量更新表数据
功能:实现将表result_good_city_dzl中的字段lat更新为表 result_good_city_lh中的lat,条件是两个表中的id一样 即: update result_good_c ...
- mybatis调用mysql的存储过程(procedure),实现查询操作(student表中的某个年级中的总人数 select (1) 或者 select (*))
step1:在mysql cmd中新建存储过程: drop procedure if exists queryCountByGrade ; delimiter // -- 定义存储过程结束符号为// ...
- mysql的存储过程,函数,事件,权限,触发器,事务,锁,视图,导入导出
1.创建过程 1.1 简单创建 -- 创建员工表 DROP TABLE IF EXISTS employee; CREATE TABLE employee( id int auto_increment ...
- MySQL数据库以及表的管理
MySQL数据库以及表的管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 今天我们探讨的话题就是如何使用MySQL做开发,我们运维的主要工作不是去开发SQL的,但尽管如此,我们有 ...
- 高可用Mysql架构_Mysql主从复制、Mysql双主热备、Mysql双主双从、Mysql读写分离(Mycat中间件)、Mysql分库分表架构(Mycat中间件)的演变
[Mysql主从复制]解决的问题数据分布:比如一共150台机器,分别往电信.网通.移动各放50台,这样无论在哪个网络访问都很快.其次按照地域,比如国内国外,北方南方,这样地域性访问解决了.负载均衡:M ...
- MySql创建存储过程,并使用事件定时调用
一.使用命令行创建存储过程的步骤 :参数详情参考 https://www.mysqlzh.com/ 1.模板 delimiter $$ # 设置分隔符为 '$$' ,mysql默认的语句分隔符为 ' ...
随机推荐
- Linux调试工具strace和gdb常用命令小结
strace和gdb是Linux环境下的两个常用调试工具,这里是个人在使用过程中对这两个工具常用参数的总结,留作日后查看使用. strace调试工具 strace工具用于跟踪进程执行时的系统调用和所接 ...
- poj2723-Get Luffy Out
一道2-SAT问题,每对钥匙需要加一条边,每扇门上的对应的要用的钥匙加一条边. 其实求解2-SAT问题,关键在于找到不能同时成立的条件,例如在本题中,每对钥匙不能同时使用,每扇门上的钥匙不能同时不使用 ...
- Day56
今天干啦啥呢 早上七点起来 天气冷了真起不来啊 再坚持坚持就好了 今天上午九点开始考数据库 我去 大学四年第一次感觉到这样的爽 作弊的爽啊 也没有完全的作弊啦 是开卷考试,反正做的很顺利了. 我和胡 ...
- C# 酒鬼买酒喝,瓶盖和空瓶子可以换新的酒
using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syst ...
- python查看删除你微信的账号
#应用环境:python2.7 #!/usr/bin/env python # coding=utf-8 from __future__ import print_function import os ...
- 使用DataReader
string sqlStr="select * from tb_news"; SqlCommand myCmd=new SqlCommand(sqlStr,myConn); myC ...
- Windows命令行(DOS命令)教程-7 (转载)http://arch.pconline.com.cn//pcedu/rookie/basic/10111/15325_6.html
11. deltree [功能] 删除目录树 [格式] [C:][path]DELTREE [C1:][path1] [[C2:][path2] […]] [说明] 这个命令将整个指定目录树全部消灭, ...
- C# 几十万级数据导出Excel,及Excel各种操作
先上导出代码 /// <summary> /// 导出速度最快 /// </summary> /// <param name="list">&l ...
- 头文件 .h 与源文件 .ccp 的区别
.h 文件一般是用来定义的,比如定义函数.类.结构体等: .cpp 文件则是对头文件的定义进行实现. include .h文件,可以调用你声明的函数.类等.当然,比较简单的类.函数,你也可以直接在头文 ...
- 犯罪团伙 codevs 3554
这是一道经典的水题,提供两种方法:①深搜 ②并查集 NO.1 深度优先搜索: #include<iostream>#include<cstdio>#include<al ...