我想向mysql数据库的一个字段里插入时间戳
但是时间值是从页面传过来的2008-11-29 或 20081129类型的时间用mysql有没有能把2008-11-29 或 20081129类型的时间 转换为时间戳 在写入数据库里例如:insert into data(name, type, time) values('moto','手机',???语句(20081129或2008-11-29));不知道mysql能不能实现啊`~` 大家帮帮忙``

解决方案 »

  1.   

    UNIX_TIMESTAMP('2008-11-29')
    select UNIX_TIMESTAMP('2006-02-28') testdate;按理说得到的时间戳应该可以直接拿来给 PHP 的 date() 等函数使用。但奇怪的是:echo date("Y-m-d",$testdate);显示出来的日期跟数据库实际的日期相比却少了一天,百思不得其解。反复查看 MySQL 关于 UNIX_TIMESTAMP 函数的说明,终于发现问题所在:“The server interprets date as a value in the current time zone and converts it to an internal value in UTC.” 原来 MySQL 的 UNIX_TIMESTAMP 函数得到的时间戳是 UTC 时间,而不是服务器设定的特定 Time zone 的时间。经过这样一转化,时间戳就凭空少了8个小时(对于咱这里来说),而 PHP 中的 timestamp 则计算的都是系统设定时区的当地时间。因此 2006-02-28 这个日期被减去了8个小时,自然变成了2006-02-27。解决方法:把这八个小时加回去(UNIX_TIMESTAMP('2006-02-28' + INTERVAL 8 HOUR));或者弃用 UNIX_TIMESTAMP 函数, 直接得到 MySQL date 字符串之后通过 strtotime() 函数来把字符串转化成真正的本地时间戳。