
-> account VARCHAR(10),
-> `time` DATETIME
->)
Query OK, 0 rows affected (0.08 sec)
mysql>
mysql>INSERT INTO time_account
-> SELECT 'a' , '2000-01-01 00:00:00' UNION ALL
-> SELECT 'b' , '2011-01-01 00:00:00'
Query OK, 2 rows affected (0.02 sec)
Records: 2 Duplicates: 0 Warnings: 0
mysql>
mysql>SELECT * FROM time_account
+---------+---------------------+
| account | time|
+---------+---------------------+
| a | 2000-01-01 00:00:00 |
| b | 2011-01-01 00:00:00 |
+---------+---------------------+
2 rows in set (0.00 sec)
mysql>UPDATE
-> time_account
->SET
-> `time` = ADDTIME(`time`, '50:00:00')
->WHERE
-> account IN ('a','b')
Query OK, 2 rows affected (0.05 sec)
Rows matched: 2 Changed: 2 Warnings: 0
mysql>SELECT * FROM time_account
+---------+---------------------+
| account | time|
+---------+---------------------+
| a | 2000-01-03 02:00:00 |
| b | 2011-01-03 02:00:00 |
+---------+---------------------+
2 rows in set (0.00 sec)
PERIOD_DIFF(P1,P2) 返回在时期P1和P2之间月数,P1和P2应该以格式YYMM或YYYYMM。注意,时期参数P1和P2不是日期值。 mysql>select PERIOD_DIFF(9802,199703) ->11 DATE_ADD(date,INTERVAL expr type) DATE_SUB(date,INTERVAL expr type) ADDDATE(date,INTERVAL expr type) SUBDATE(date,INTERVAL expr type) 这些功能执行日期运算。对于MySQL 3.22,他们是新的。ADDDATE()和SUBDATE()是DATE_ADD()和DATE_SUB()的同义词。 在MySQL 3.23中,你可以使用+和-而不是DATE_ADD()和DATE_SUB()。(见例子)date是一个指定开始日期的 DATETIME或DATE值,expr是指定加到开始日期或从开始日期减去的间隔值一个表达式,expr是一个字符串;它可以以 一个“-”开始表示负间隔。type是一个关键词,指明表达式应该如何被解释。EXTRACT(type FROM date)函数从日期 中返回“type”间隔。下表显示了type和expr参数怎样被关联: type值 含义 期望的expr格式 SECOND 秒 SECONDS MINUTE 分钟 MINUTES HOUR 时间 HOURS DAY 天 DAYS MONTH 月 MONTHS YEAR 年 YEARS MINUTE_SECOND 分钟和秒 "MINUTES:SECONDS" HOUR_MINUTE 小时和分钟 "HOURS:MINUTES" DAY_HOUR 天和小时 "DAYS HOURS" YEAR_MONTH 年和月 "YEARS-MONTHS" HOUR_SECOND 小时, 分钟, "HOURS:MINUTES:SECONDS" DAY_MINUTE 天, 小时, 分钟 "DAYS HOURS:MINUTES" DAY_SECOND 天, 小时, 分钟, 秒 "DAYS HOURS:MINUTES:SECONDS" MySQL在expr格式中允许任何标点分隔符。表示显示的是建议的分隔符。如果date参数是一个DATE值并且你的计算仅仅 包含YEAR、MONTH和DAY部分(即,没有时间部分),结果是一个DATE值。否则结果是一个DATETIME值。 mysql>SELECT "1997-12-31 23:59:59" + INTERVAL 1 SECOND ->1998-01-01 00:00:00 mysql>SELECT INTERVAL 1 DAY + "1997-12-31" ->1998-01-01 mysql>SELECT "1998-01-01" - INTERVAL 1 SECOND ->1997-12-31 23:59:59 mysql>SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 SECOND) ->1998-01-01 00:00:00 mysql>SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 DAY) ->1998-01-01 23:59:59 mysql>SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL "1:1" MINUTE_SECOND) ->1998-01-01 00:01:00 mysql>SELECT DATE_SUB("1998-01-01 00:00:00", INTERVAL "1 1:1:1" DAY_SECOND) ->1997-12-30 22:58:59 mysql>SELECT DATE_ADD("1998-01-01 00:00:00", INTERVAL "-1 10" DAY_HOUR) ->1997-12-30 14:00:00 mysql>SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY) ->1997-12-02 mysql>SELECT EXTRACT(YEAR FROM "1999-07-02") ->1999 mysql>SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03") ->199907 mysql>SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03") ->20102看看mysql文档里面关于timestamp的说明会清楚一些这块是容易弄错,建表的第一列timestamp属性的字段如果不显示给默认值,都会自动更新.
http://dev.mysql.com/doc/refman/5.1/zh/column-types.html#datetime
11.3.1.1.
自MySQL
4.1以来的TIMESTAMP属性
我觉得一般用date就够用了
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)