Mysql中将日期转化为毫秒

时间:2024-03-05 10:35:07

一:将毫秒值转化为指定日期格式

使用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

其中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\');    //这个只是秒值,若需要毫秒值则再乘以1000

结果

1306771200

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