Chinaunix首页 | 论坛 | 博客
  • 博客访问: 201573
  • 博文数量: 87
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 840
  • 用 户 组: 普通用户
  • 注册时间: 2012-07-18 21:12
文章分类

全部博文(87)

文章存档

2014年(86)

我的朋友

分类: Mysql/postgreSQL

2014-05-28 11:13:12

 MySQL 获得当前时间戳函数:current_timestamp, current_timestamp()
mysql> select current_timestamp, current_timestamp();

+---------------------+---------------------+
| current_timestamp | current_timestamp() |
+---------------------+---------------------+
| 2008-08-09 23:22:24 | 2008-08-09 23:22:24 |
+---------------------+---------------------+

2. MySQL (Unix 时间戳、日期)转换函数:
unix_timestamp(),
unix_timestamp(date),
from_unixtime(unix_timestamp),
from_unixtime(unix_timestamp,format)

下面是示例:
select unix_timestamp(); -- 1218290027
select unix_timestamp('2008-08-08'); -- 1218124800
select unix_timestamp('2008-08-08 12:30:00'); -- 1218169800

select from_unixtime(1218290027); -- '2008-08-09 21:53:47'
select from_unixtime(1218124800); -- '2008-08-08 00:00:00'
select from_unixtime(1218169800); -- '2008-08-08 12:30:00'

select from_unixtime(1218169800, '%Y %D %M %h:%i:%s %x'); -- '2008 8th August 12:30:00 2008'

3. MySQL 时间戳(timestamp)转换、增、减函数:
timestamp(date) -- date to timestamp
timestamp(dt,time) -- dt + time
timestampadd(unit,interval,datetime_expr) --
timestampdiff(unit,datetime_expr1,datetime_expr2) --

请看示例部分:
select timestamp('2008-08-08'); -- 2008-08-08 00:00:00
select timestamp('2008-08-08 08:00:00', '01:01:01'); -- 2008-08-08 09:01:01
select timestamp('2008-08-08 08:00:00', '10 01:01:01'); -- 2008-08-18 09:01:01

select timestampadd(day, 1, '2008-08-08 08:00:00'); -- 2008-08-09 08:00:00
select date_add('2008-08-08 08:00:00', interval 1 day); -- 2008-08-09 08:00:00

MySQL timestampadd() 函数类似于 date_add()。
select timestampdiff(year,'2002-05-01','2001-01-01'); -- -1
select timestampdiff(day ,'2002-05-01','2001-01-01'); -- -485
select timestampdiff(hour,'2008-08-08 12:00:00','2008-08-08 00:00:00'); -- -12

select datediff('2008-08-08 12:00:00', '2008-08-01 00:00:00'); -- 7

MySQL timestampdiff() 函数就比 datediff() 功能强多了,datediff() 只能计算两个日期(date)之间相差的天数。




#!/bin/bash


ps="meiyu#super^^"
sql="
use zabbix;
DELETE  FROM history WHERE clock < unix_timestamp(DATE_ADD(now(),INTERVAL -1 day));
optimize table history;
DELETE FROM history_str WHERE clock < unix_timestamp(DATE_ADD(now(),INTERVAL -1 day));
optimize table history_str;
DELETE FROM history_uint WHERE clock < unix_timestamp(DATE_ADD(now(),INTERVAL -1 day));
optimize table history_uint;
DELETE FROM trends WHERE clock optimize table trends;
DELETE FROM trends_uint WHERE clock < unix_timestamp(DATE_ADD(now(),INTERVAL -1 day));
optimize table trends_uint;
DELETE FROM events WHERE clock < unix_timestamp(DATE_ADD(now(),INTERVAL -1 day));
optimize table events;
"
echo "------optimize start------------------"
mysql -uroot -p$ps -e "$sql" >> /root/optimizedaily.log
echo "------optimize end------------------"



阅读(1578) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~