mysql中:UNIX_TIMESTAMP(),UNIX_TIMESTAMP(date)
若无参数调用,则返回一个 Unixtimestamp('1970-01-0100:00:00'GMT之后的秒数)作为无符号整数。若用date来调用 UNIX_TIMESTAMP(),它会将参数值以'1970-01-0100:00:00'GMT后的秒数的形式返回。date可以是一个 DATE字符串、一个DATETIME字符串、一个TIMESTAMP或一个当地时间的YYMMDD或YYYMMDD格式的数字。
mysql>SelectUNIX_TIMESTAMP();
->882226357
mysql>SelectUNIX_TIMESTAMP('1997-10-0422:23:00');
->875996580
当UNIX_TIMESTAMP 被用在TIMESTAMP列时,函数直接返回内部时戳值,而不进行任何隐含的“string-to-Unix-timestamp”转化。假如你 向UNIX_TIMESTAMP()传递一个溢出日期,它会返回0,但请注意只有基本范围检查会被履行(年份从1970到2037,月份从01 到12,日期从01到31)。
这里我们可以使用
FROM_UNIXTIME(unix_timestamp),FROM_UNIXTIME(unix_timestamp,format) 来格式化一个UNIX_TIMESTAMP()时间戳,它将返回'YYYY-MM-DDHH:MM:SS'或YYYYMMDDHHMMSS格式值的 unix_timestamp参数表示,具体格式取决于该函数是否用在字符串中或是数字语境中。
若format已经给出,则结果的格式是根据format字符串而定。format可以包含同DATE_FORMAT()函数输入项列表中相同的说明符。
mysql>SelectFROM_UNIXTIME(875996580);
->'1997-10-0422:23:00'
mysql>SelectFROM_UNIXTIME(875996580)+0;
->19971004222300
mysql>SelectFROM_UNIXTIME(UNIX_TIMESTAMP(),
->'%Y%D%M%h:%i:%s%x');
->'20036thAugust06:22:582003'
php中:time()
time--返回当前的Unix时间戳
返回自从Unix纪元(格林威治时间1970年1月1日00:00:00)到当前时间的秒数。
从字面上理解他们是一样的,都是返回自从Unix纪元到当前时间的秒数。
笔者在同一台服务器上做了一个测试,发现两者返回的结果是一样的。
在mysql中用FROM_UNIXTIME(1156219870,'%y-%m-%d')
和php中用date("y-m-d",1156219870)结果也是一样相同的!唯一不肯确定的是那一个反应更加快速。不过我还是倾向与用php中的time()函数!
若无参数调用,则返回一个 Unixtimestamp('1970-01-0100:00:00'GMT之后的秒数)作为无符号整数。若用date来调用 UNIX_TIMESTAMP(),它会将参数值以'1970-01-0100:00:00'GMT后的秒数的形式返回。date可以是一个 DATE字符串、一个DATETIME字符串、一个TIMESTAMP或一个当地时间的YYMMDD或YYYMMDD格式的数字。
mysql>SelectUNIX_TIMESTAMP();
->882226357
mysql>SelectUNIX_TIMESTAMP('1997-10-0422:23:00');
->875996580
当UNIX_TIMESTAMP 被用在TIMESTAMP列时,函数直接返回内部时戳值,而不进行任何隐含的“string-to-Unix-timestamp”转化。假如你 向UNIX_TIMESTAMP()传递一个溢出日期,它会返回0,但请注意只有基本范围检查会被履行(年份从1970到2037,月份从01 到12,日期从01到31)。
这里我们可以使用
FROM_UNIXTIME(unix_timestamp),FROM_UNIXTIME(unix_timestamp,format) 来格式化一个UNIX_TIMESTAMP()时间戳,它将返回'YYYY-MM-DDHH:MM:SS'或YYYYMMDDHHMMSS格式值的 unix_timestamp参数表示,具体格式取决于该函数是否用在字符串中或是数字语境中。
若format已经给出,则结果的格式是根据format字符串而定。format可以包含同DATE_FORMAT()函数输入项列表中相同的说明符。
mysql>SelectFROM_UNIXTIME(875996580);
->'1997-10-0422:23:00'
mysql>SelectFROM_UNIXTIME(875996580)+0;
->19971004222300
mysql>SelectFROM_UNIXTIME(UNIX_TIMESTAMP(),
->'%Y%D%M%h:%i:%s%x');
->'20036thAugust06:22:582003'
php中:time()
time--返回当前的Unix时间戳
返回自从Unix纪元(格林威治时间1970年1月1日00:00:00)到当前时间的秒数。
从字面上理解他们是一样的,都是返回自从Unix纪元到当前时间的秒数。
笔者在同一台服务器上做了一个测试,发现两者返回的结果是一样的。
在mysql中用FROM_UNIXTIME(1156219870,'%y-%m-%d')
和php中用date("y-m-d",1156219870)结果也是一样相同的!唯一不肯确定的是那一个反应更加快速。不过我还是倾向与用php中的time()函数!