这篇文章将为大家详细讲解有关MySQL 5.1事件调度器中状态查看、开启命令以及测试的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

创新互联公司从2013年开始,是专业互联网技术服务公司,拥有项目网站制作、成都网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元沂源做网站,已为上家服务,为沂源各地企业和个人服务,联系电话:18980820575
	自MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操作系统的计划任务来执行的工作。更值得一提的是MYSQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:下的CRON或Windows下的任务计划)只能精确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就非常适合。
	事件调度器有时也可称为临时触发器(temporal triggers),因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。
	在使用这个功能之前必须确保event_scheduler已开启,可执行
	SET GLOBAL event_scheduler = 1;
	或我们可以在配置my.ini文件 中加上 event_scheduler = 1或
	SET GLOBAL event_scheduler = ON;
	来开启,也可以直接在启动命令加上“–event_scheduler=1”,例如:
	d ... --event_scheduler=1
	要查看当前是否已开启事件调度器,可执行如下SQL:
	SHOW VARIABLES LIKE 'event_scheduler';
	或
	SELECT @@event_scheduler;
	或
	拥有 SUPER 权限的账户执行 SHOW PROCESSLIST 就可以看到这个线程了
	5.3、定时服务配置
	先来看一下它的语法:
	CREATE EVENT [IF NOT EXISTS] event_name
	    ON SCHEDULE schedule
	    [ON COMPLETION [NOT] PRESERVE]
	    [ENABLE | DISABLE]
	    [COMMENT 'comment']
	    DO sql_statement;
	schedule:
	    AT TIMESTAMP [+ INTERVAL INTERVAL]
	| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]
	INTERVAL:
	    quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
	              WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
	              DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}
	5.3.1每秒插入一条记录到数据表
	USE test;
	CREATE TABLE aaa (timeline TIMESTAMP);
	CREATE EVENT e_test_insert
	ON SCHEDULE EVERY 1 SECOND
	DO INSERT INTO test.aaa VALUES (CURRENT_TIMESTAMP);
	等待3秒钟后,再执行查询看看:
	mysql> SELECT * FROM aaa;
	+---------------------+
	| timeline            |
	+---------------------+
	| 2007-07-18 20:44:26 |
	| 2007-07-18 20:44:27 |
	| 2007-07-18 20:44:28 |
	+---------------------+
	5.3.2 5秒(天)后清空test表
	CREATE EVENT e_test
	ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 SECOND
	DO TRUNCATE TABLE test.aaa;
	CREATE EVENT e_test
	ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 DAY
	DO TRUNCATE TABLE test.aaa;
	5.3.3 2008年5月23日9点39分20秒整清空test表
	CREATE EVENT e_test
	ON SCHEDULE AT TIMESTAMP '2008-05-23 9:39:20'
	DO TRUNCATE TABLE test.aaa;
	这个测试有问题。还不太明白原因。
	5.3.4 每天定时清空test表
	CREATE EVENT e_test
	ON SCHEDULE EVERY 1 DAY
	DO TRUNCATE TABLE test.aaa;
	5.3.5 5天后开启每天定时清空test表
	CREATE EVENT e_test
	ON SCHEDULE EVERY 1 DAY
	STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
	DO TRUNCATE TABLE test.aaa;
	这里5天也可以为0天,当时就开启清空表
	5.3.6 每天定时清空test表,5天后停止执行
	CREATE EVENT e_test
	ON SCHEDULE EVERY 1 DAY
	ENDS CURRENT_TIMESTAMP + INTERVAL 5 DAY
	DO TRUNCATE TABLE test.aaa;
	该设置要求天数大于1,否则报错。而且创建不成功
5.3.7 5天后开启每天定时清空test表,一个月后停止执行
	CREATE EVENT e_test
	ON SCHEDULE EVERY 1 DAY
	STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
	ENDS CURRENT_TIMESTAMP + INTERVAL 1 MONTH
	DO TRUNCATE TABLE test.aaa;[ON COMPLETION [NOT] PRESERVE]
	可以设置这个事件是执行一次还是持久执行,默认为NOT PRESERVE。
	该事件会停止每隔一秒插入数据的事件,感觉这点上mysql做的还是有问题。
	5.3.8 每天定时清空test表(只执行一次,任务完成后就终止该事件)
	CREATE EVENT e_test
	ON SCHEDULE EVERY 1 DAY
	ON COMPLETION NOT PRESERVE
	DO TRUNCATE TABLE test.aaa;
	[ENABLE | DISABLE]可是设置该事件创建后状态是否开启或关闭,默认为ENABLE。
	[COMMENT ‘comment’]可以给该事件加上注释。
	5.4、定时服务日常维护测试
	5.4.1 修改事件(ALTER EVENT)
	ALTER EVENT event_name
	    [ON SCHEDULE schedule]
	    [RENAME TO new_event_name]
	    [ON COMPLETION [NOT] PRESERVE]
	    [COMMENT 'comment']
	    [ENABLE | DISABLE]
	    [DO sql_statement]
	a、临时关闭事件
	ALTER EVENT e_test DISABLE;
	b、开启事件
	ALTER EVENT e_test ENABLE;
	c、将每天清空test表改为5天清空一次:
	ALTER EVENT e_test
	ON SCHEDULE EVERY 5 DAY;
	d、重命名事件并加上注释
	alter event test.new_e_test rename to e_test comment 'e_test_cm';
	5.4.2 删除事件(DROP EVENT)
	语法很简单,如下所示:
	DROP EVENT [IF EXISTS] event_name例如删除前面创建的e_test事件
	DROP EVENT e_test;当然前提是这个事件存在,否则会产生ERROR 1513 (HY000): Unknown event错误,因此最好加上IF EXISTS
	DROP EVENT IF EXISTS e_test;
	5.4.3 查看事件
	a、查看一个event的详细信息可以用下面的视图:
	SELECT * FROM INFORMATION_SCHEMA.EVENTS WHERE EVENT_NAME = 'e_test_insert'   AND EVENT_SCHEMA = 'test'\G;
	b、简要列出所有的event:show events
	语法:
	SHOW EVENTS [FROM schema_name]
	    [LIKE 'pattern' | WHERE expr]
	格式化显示所有event
	SHOW EVENTS\G
	格式化显示test用户的event
	show events FROM test;
	c、查看event的创建信息
	SHOW CREATE EVENT event_name
	show create event test.e_test\G
关于“mysql 5.1事件调度器中状态查看、开启命令以及测试的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
网页题目:mysql5.1事件调度器中状态查看、开启命令以及测试的示例分析
标题路径:http://www.scyingshan.cn/article/iphepp.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 