本文对mysql中的UNIX_TIMESTAMP()函数和php中的time()函数的区别做了详细的分析和介绍,供大家参考。
mysql 中:UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date)
如果没有调用参数,UNIX时间戳(GMT 1970-01-01 00:00 之后的秒数)将作为无符号整数返回。如果使用date调用UNIX_TIMESTAMP(),它将返回参数值,即GMT 1970-01-01 00:00 之后的秒数。DATE可以是日期字符串、日期时间字符串、时间戳或本地时间YYMMDD或YYMMDD格式的数字。MySQL SELECT UNIX _ TIMESTAMP();-882226357 my SQL SELECT UNIX _ TIMESTAMP( 1997-10-04 22:23:00 );-875996580当在TIMESTAMP列中使用UNIX_TIMESTAMP时,函数直接返回内部时间戳值,而不进行任何隐式的“字符串到Unix-timestamp”转换。如果将溢出日期传递给UNIX_TIMESTAMP(),它将返回0,但请注意,只执行基本范围检查(1970年到2037年的年份,01到12年的月份,01到31年的日期)。这里我们可以使用
from _ Unix Time (UNIX_TIMESTAMP),from _ Unix Time(UNIX_TIMESTAMP,format)格式化一个unix_timestamp()时间戳,将返回Unix _ TIMESTAMP参数 YYYY-MM-DD HH:MM:SS 或YYYYMMDDHHMMSS格式值,表示如果已经给定格式,结果的格式取决于格式字符串。Format可以包含与DATE_FORMAT()函数中的输入项列表相同的说明符。MySQL SELECT FROM _ UNIX time(875996580);- 1997-10-04 22:23:00 MySQL SELECT FROM _ UNIX time(875996580)0;-19971004222300 my SQL SELECT FROM _ UNIX time(UNIX _ TIMESTAMP(),- % Y % D % M % h:% I:% s % x );- 2003年8月6日06:22:58 2003php中:time()
time -返回当前Unix时间戳。返回从Unix时代(00:00:00 GMT,1970年1月1日)到当前时间的秒数。从字面上看,它们是一样的。它们都返回从Unix时代到当前时间的秒数。笔者在同一个服务器上做了一个测试,发现两者返回的结果是一样的。在mysql中使用from _ unixtime (1156219870, % y-%m-%d )和在php中使用date( y-m-d ,1156219870)结果是一样的!我唯一不确定的是哪个反应更快。但是我还是更喜欢用php中的time()函数!