mysql时间问题

1. mysql中提供的日期和时间:

mysql> desc test_time;
+--------+---------------------+------+-----+-------------------+-----------------------------+
| Field  | Type                | Null | Key | Default           | Extra                       |
+--------+---------------------+------+-----+-------------------+-----------------------------+
| id     | bigint(20) unsigned | NO   | PRI | NULL              | auto_increment              |
| t_date | date                | YES  |     | NULL              |                             |
| t_time | time                | YES  |     | NULL              |                             |
| t_ts   | timestamp           | NO   |     | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
| t_dt   | datetime            | YES  |     | NULL              |                             |
+--------+---------------------+------+-----+-------------------+-----------------------------+
5 rows in set (0.00 sec)

mysql> insert into test_time(t_date,t_time,t_dt) values(curdate(),curtime(), now());
Query OK, 1 row affected (0.00 sec)

mysql> select * from test_time;
+----+------------+----------+---------------------+---------------------+
| id | t_date     | t_time   | t_ts                | t_dt                |
+----+------------+----------+---------------------+---------------------+
|  1 | 2014-06-19 | 15:53:39 | 2014-06-19 15:53:39 | 2014-06-19 15:53:39 |
|  2 | 2014-06-19 | 15:53:57 | 2014-06-19 15:53:57 | 2014-06-19 15:53:57 |
|  3 | 2014-06-19 | 15:54:01 | 2014-06-19 15:54:01 | 2014-06-19 15:54:01 |
|  4 | 2014-06-19 | 15:54:38 | 2014-06-19 15:54:38 | 2014-06-19 15:54:38 |
+----+------------+----------+---------------------+---------------------+
4 rows in set (0.00 sec)


2. 当修改表中数据时,t_ts自动更新为当前时间:

mysql> update test_time set age=4 where id=4;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> 
mysql> select * from test_time;
+----+------------+----------+---------------------+---------------------+-----+
| id | t_date     | t_time   | t_ts                | t_dt                | age |
+----+------------+----------+---------------------+---------------------+-----+
|  1 | 2014-06-19 | 15:53:39 | 2014-06-19 15:59:32 | 2014-06-19 15:53:39 |   1 |
|  2 | 2014-06-19 | 15:53:57 | 2014-06-19 15:59:41 | 2014-06-19 15:53:57 |   2 |
|  3 | 2014-06-19 | 15:54:01 | 2014-06-19 15:59:49 | 2014-06-19 15:54:01 |   3 |
|  4 | 2014-06-19 | 15:54:38 | 2014-06-19 15:59:55 | 2014-06-19 15:54:38 |   4 |
+----+------------+----------+---------------------+---------------------+-----+

3. 时间比较:

mysql> SELECT * FROM test_time WHERE TO_DAYS(NOW()) - TO_DAYS(t_date) <= 30;
+----+------------+----------+---------------------+---------------------+-----+
| id | t_date     | t_time   | t_ts                | t_dt                | age |
+----+------------+----------+---------------------+---------------------+-----+
|  1 | 2014-06-19 | 15:53:39 | 2014-06-19 15:59:32 | 2014-06-19 15:53:39 |   1 |
|  2 | 2014-06-19 | 15:53:57 | 2014-06-19 15:59:41 | 2014-06-19 15:53:57 |   2 |
|  3 | 2014-06-19 | 15:54:01 | 2014-06-19 15:59:49 | 2014-06-19 15:54:01 |   3 |
|  4 | 2014-06-19 | 15:54:38 | 2014-06-19 15:59:55 | 2014-06-19 15:54:38 |   4 |
+----+------------+----------+---------------------+---------------------+-----+
4 rows in set (0.00 sec)

select * from test_time where unix_timestamp(t_ts) >= unix_timestamp() -1800 and unix_timestamp(t_ts) <= unix_timestamp();


4. mysql设计friendfeed

  http://backchannel.org/blog/friendfeed-schemaless-mysql



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值