日期:2014-05-16  浏览次数:20717 次

[MYSQL]时间毫秒数转换

java中常用bigint字段保存时间,通常将时间保存为一大串数字,每次取出需要在程序里转换,有时候程序里不方便,可以使用MYSQL自带的函数FROM_UNIXTIME(unix_timestamp,format)。

举例:

select FROM_UNIXTIME(1364176514656/1000,'%Y-%m-%d %h:%i:%s') as date ;

结果为:

2013-03-25 09:55:15

?

FROM_UNIXTIME(unix_timestamp,format)

其中unix_timestamp为字段值/1000.

format可以使用的值为:

%M 月名字(January……December)

%W 星期名字(Sunday……Saturday)?

%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)?

%Y 年, 数字, 4 位

%y 年, 数字, 2 位?

%a 缩写的星期名字(Sun……Sat)?

%d 月份中的天数, 数字(00……31)?

%e 月份中的天数, 数字(0……31)?

%m 月, 数字(01……12)?

%c 月, 数字(1……12)?

%b 缩写的月份名字(Jan……Dec)?

%j 一年中的天数(001……366)?

%H 小时(00……23)?

%k 小时(0……23)?

%h 小时(01……12)?

%I 小时(01……12)?

%l 小时(1……12)?

%i 分钟, 数字(00……59)?

%r 时间,12 小时(hh:mm:ss [AP]M)?

%T 时间,24 小时(hh:mm:ss)?

%S 秒(00……59) %s 秒(00……59)?

%p AM或PM?

%w 一个星期中的天数(0=Sunday ……6=Saturday )?

%U 星期(0……52), 这里星期天是星期的第一天?

%u 星期(0……52), 这里星期一是星期的第一天?

%% 一个文字“%”。

同理,有时我们也想把datetime类型的数据转换为int类型保存到数据库。那么这时候就需要用到函数

select UNIX_TIMESTAMP('2011-05-31 23:59:59');

结果

1306771200

注意 UNIX_TIMESTAMP该函数只返回1970。。。。到现在的秒数。如果算上一个函数一样是毫秒数,则还需要在乘以1000