DATE_SUB() 函数
DATE_SUB() //函数从日期减去指定的时间间隔。
DATE_SUB(date,INTERVAL expr type) //语法
type
参数
MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR
SECOND_MICROSECOND
MINUTE_MICROSECOND
MINUTE_SECOND
HOUR_MICROSECOND
HOUR_SECOND
HOUR_MINUTE
DAY_MICROSECOND
DAY_SECOND
DAY_MINUTE
DAY_HOUR
YEAR_MONTH
CURDATE() 函数
CURDATE() // 函数返回当前的日期。
SELECT NOW(),CURDATE(),CURTIME()
//例子NOW() CURDATE() CURTIME()
//2008-12-29 16:25:46 2008-12-29 16:25:46
# interval()函数
INTERVAL()
函数进行比较列表 (N,N1,N2,N3
等等)中的 N 值。该函数如果 N<N1
返回 0,如果 N<N2
返回 1,如果
N<N3返回
2等等。如果
N为
NULL,它将返回
-1。列表值必须是
N1<N2<N3的形式才能正常工作。下面的代码是显示
INTERVAL()` 函数如何工作的一个简单的例子:
SELECT NOW()-INTERVAL 24 HOUR
if exists和if not exists
if not exists
即如果不存在,if exists
即如果存在
使用
1.判断数据库不存在时
if not exists(select * from sys.databases where name = ‘database_name’)
2.判断表不存在时
if not exists (select * from sysobjects where id = object_id(‘table_name’) and OBJECTPROPERTY(id, ’IsUserTable’) = 1)
3.判断列不存在
if not exists (select * from syscolumns where id=object_id(’table_name’) and name=’column_name’)
开始创建事件
创建事件条件:
delete FROM userInfo WHERE find_Data<DATE_SUB(CURTIME(),INTERVAL 24 HOUR)
//删除超过24小时前的数据
设置
定义者
指定当在事件运行时检查访问权限要使用的用户帐号。默认定义者值是运行 CREATE EVENT
语句的的用户。(这是和 DEFINER = CURRENT_USER
相同。)如果给予一个用户值,它应该是一个 ‘user_name‘@‘host_name‘
格式的 MySQL
帐号(使用在 GRANT
语句相同的格式)。user_name
及 host_name
值都是必须的。
状态
你可以创建一个事件但可以用 DISABLE
关键字保持不激活。或者,你可以用 ENABLE
来出明确默认状态,这是激活。
ON COMPLETION
正常情况下,一旦事件已过期,它将立即删除。你可以通过指定 ON COMPLETION PRESERVE
来重写此性能。使用 ON COMPLETION NOT PRESERVE
只是使默认非持久性的性能明确。
AT
AT timestamp
用于一次性事件。它指定该事件只运行一次于 timestamp
的日期和时间,它必须同时包含日期和时间,或必须是一个解析为 datetime
值的表达式。使用 +INTERVAL
来创建一个事件,它发生在与当前日期和时间有关的将来某个时候。
EVERY
在定期间隔重复的行动,你可以用一个 EVERY
子句之后是一个 interval
。(+INTERVAL
与 EVERY
不能同时使用。)
STARTS
EVERY
子句还可能包含一个非必须的 STARTS
子句。STARTS
之后是一个 timestamp
值表示行动应该何时开始重复,也可以用 +INTERVAL
间隔以指定「由现在开始」的时间量。
例如:EVERY 3 MONTH STARTS CURRENT_TIMESTAMP + 1 WEEK
的意思是「每 3 个月,从现在起一周后开始」。
ENDS
EVERY
子句还可包含一个非必须的 ENDS
子句。ENDS
关键字之后是一个 timestamp
值告诉 MySQL
何时停止重复事件。你也可以用 +INTERVAL
间隔与 ENDS
一起。
例如:EVERY 12 HOUR STARTS CURRENT_TIMESTAMP + INTERVAL 30 MINUTE ENDS CURRENT_TIMESTAMP + INTERVAL 4 WEEK
相当于「每十二个小时,从现在起三十分钟后开始,并于现在起四个星期后结束」。
timestamp
必须在未来的 - 你不能安排一个事件发生在过去。
interval
区间由两部份组成,数量和时间单位。
保存
最后点击保存就行
网友评论