mysql 时间戳转换函数 unix_timestamp和from_unixtime使用方法

1.unix_timestamp

将时间转化为时间戳。将 date 类型数据转换成 timestamp 时间戳形式

默认取当前时间的时间戳

mysql> select unix_timestamp();
+——————+
| unix_timestamp() |
+——————+
|       1436775578 |
+——————+
1 row in set (0.01 sec)

 

mysql> select unix_timestamp('2015-07-13 16:20:20');
+—————————————+
| unix_timestamp('2015-07-13 16:20:20') |
+—————————————+
|                            1436775620 |
+—————————————+
1 row in set (0.00 sec)

 

2.from_unixtime

将时间戳 timestamp 形式整数 转化为 date 类型

mysql>  select from_unixtime(1436775620);
+—————————+
| from_unixtime(1436775620) |
+—————————+
| 2015-07-13 16:20:20       |
+—————————+
1 row in set (0.00 sec)

当然也可以指定输出的时间格式:

mysql>  select from_unixtime(1436775620,'%Y%m%d');
+————————————+
| from_unixtime(1436775620,'%Y-%m-%d') |
+————————————+
| 2015-07-13                           |
+————————————+

 

3.关于mysql 时间戳的限制

目前timestamp 所能表示的范围在 1970  -  2038之间 。

超过这个范围 得到的时间将会溢出 得到的时间是null.

mysql>  select from_unixtime(0);
+———————+
| from_unixtime(0)    |
+———————+
| 1970-01-01 08:00:00 |
+———————+

mysql> select from_unixtime(2247483647);
+—————————+
| from_unixtime(2247483647) |
+—————————+
| 2038-01-19 11:14:07       |
+—————————+
1 row in set (0.00 sec)

4、除了mysql php也可以达到同样的效果,例子如下

(完整的 年月日时分秒)
 
php中UNIX时间戳转换为日期用函数 : date()
 
date('Y-m-d H:i:s', 1156219870);
 
php中日期转换为UNIX时间戳用函数 :strtotime()
 
strtotime('2010-03-24 08:15:42');

PHP 提供了函数可以方便的将各种形式的日期转换为时间戳,该类函数主要是:

strtotime():将任何英文文本的日期时间描述解析为时间戳。
mktime():从日期取得时间戳。
strtotime()

strtotime() 函数用于将英文文本字符串表示的日期转换为时间戳,为 date() 的反函数,成功返回时间戳,否则返回 FALSE 。语法:

int strtotime ( string time [, int now] )
参数 time 为被解析的字符串,是根据 GNU 日期输入格式表示的日期。

例子:

<?php
echo strtotime("2009-10-21 16:00:10"); //输出 1256112010
echo strtotime("10 September 2008"); //输出 1220976000
echo strtotime("+1 day"), "<br />"; //输出明天此时的时间戳
?>
mktime()

mktime() 函数用于从日期取得时间戳,成功返回时间戳,否则返回 FALSE 。语法:

int mktime(时, 分, 秒, 月, 日, 年)
例子:

<?php
echo mktime(21, 50, 55, 07, 14, 2010);  //输出“1279115455”
?>
参数可以从右向左省略,任何省略的参数会被设置成本地日期和时间的当前值。

mktime() 在做日期计算和验证方面很有用,它会自动计算超出范围的输入的正确值。例如下面例子输出的都是 2008-01-01:

<?php
echo date("Y-m-d", mktime(0, 0, 0, 12, 32, 2007));
echo date("Y-m-d", mktime(0, 0, 0, 13, 1, 2007));
?>
下个月的最后一天。任何给定月份的最后一天都可以被表示为下个月的第 "0" 天,而不是 -1 天,如下面的例子:

<?php
$lastday = mktime(0, 0, 0, 3, 0, 2008);
echo strftime("2008年最后一天是:%d", $lastday);
// 2008年最后一天是:29
?>
自定义函数

下面的函数与strtotime功能差不多。

<?php
$date_str = "2011-09-11 17:00:00";
echo $time_str = str_format_time($date_str);

function str_format_time($timestamp = '')
{  
 if (preg_match("/[0-9]{4}-[0-9]{1,2}-[0-9]{1,2} (0[0-9]|1[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])/i", $timestamp))
 {
  list($date,$time)=explode(" ",$timestamp);
  list($year,$month,$day)=explode("-",$date);
     list($hour,$minute,$seconds )=explode(":",$time);
   $timestamp=gmmktime($hour,$minute,$seconds,$month,$day,$year);
 }
 else
 {
  $timestamp=time();
 }
 return $timestamp;
}

echo '<br />';
echo date("Y-m-d H:i:s", $time_str);

?>

时间: 2024-11-26 18:22:36

mysql 时间戳转换函数 unix_timestamp和from_unixtime使用方法的相关文章

mysql时间戳转换函数 unix

 1.unix_timestamp 将时间转化为时间戳.将 date 类型数据转换成 timestamp 时间戳形式 默认取当前时间的时间戳 mysql> select unix_timestamp(); +------+ | unix_timestamp() | +------+ |       1436775578 | +------+ 1 row in set (0.01 sec)   mysql> select unix_timestamp('2015-07-13 16:20:20')

mysql时间转换函数的用法

mysql时间转换函数的用法 返回日期date的星期索引(1=星期天,2=星期一, --7=星期六).这些索引值对应于ODBC标准. mysql> select DAYOFWEEK(2007-10-31); -> 4 WEEKDAY(date) 返回date的星期索引(0=星期一,1=星期二, --6= 星期天). mysql> select WEEKDAY('2007-10-31 13:05:00'); -> 2 mysql> select WEEKDAY('2007-10

php实现兼容2038年后Unix时间戳转换函数

 这篇文章主要介绍了php实现兼容2038年后Unix时间戳转换函数,使用方法和就的函数一样,非常实用,推荐给大家,希望大家能够喜欢.     使用方法跟旧的函数一模一样.   代码如下: function fun_strtotime($var1=0,$var2=0){ if(!$var2){ $var2 = $var1; $var1 = 0; } if(is_numeric($var2)){ $var2 = '@'.$var2; } try{ $date = new DateTime($var

mysql 时间转换函数的使用方法第1/2页_Mysql

mysql 时间转换函数的用法 DAYOFWEEK(date)   返回日期date的星期索引(1=星期天,2=星期一, --7=星期六).这些索引值对应于ODBC标准.   mysql> select DAYOFWEEK(2007-10-31);   -> 4 WEEKDAY(date)   返回date的星期索引(0=星期一,1=星期二, --6= 星期天).   mysql> select WEEKDAY('2007-10-31 13:05:00');   -> 2 mysq

php实现兼容2038年后Unix时间戳转换函数_php实例

使用方法跟旧的函数一模一样. 复制代码 代码如下: function fun_strtotime($var1=0,$var2=0){     if(!$var2){         $var2 = $var1;         $var1 = 0;     }     if(is_numeric($var2)){        $var2 = '@'.$var2;     }     try{         $date  =  new DateTime($var2);         $dat

php把时间戳转换成多少时间之前函数的实例_php实例

如下所示: function wordTime($time) { $time = (int) substr($time, 0, 10); $int = time() - $time; $str = ''; if ($int <= 2){ $str = sprintf('刚刚', $int); }elseif ($int < 60){ $str = sprintf('%d秒前', $int); }elseif ($int < 3600){ $str = sprintf('%d分钟前', f

MYSQL教程:UNIX时间戳和日期转换函数

UNIX时间戳转换为日期用函数: FROM_UNIXTIME() select FROM_UNIXTIME(1156219870); 日期转换为UNIX时间戳用函数: UNIX_TIMESTAMP() Select UNIX_TIMESTAMP('2006-11-04 12:23:00′); 例:mysql查询当天的记录数: $sql="select * from message Where DATE_FORMAT(FROM_UNIXTIME(chattime),'%Y-%m-%d') = DA

FROM_UNIXTIME 格式化MYSQL时间戳函数_Mysql

函数:FROM_UNIXTIME作用:将MYSQL中以INT(11)存储的时间以"YYYY-MM-DD"格式来显示.语法:FROM_UNIXTIME(unix_timestamp,format) 返回表示 Unix 时间标记的一个字符串,根据format字符串格式化.format可以包含与DATE_FORMAT()函数列出的条目同样的修饰符. 根据format字符串格式化date值.下列修饰符可以被用在format字符串中: %M 月名字(January--December)%W 星期

JavaScript日期时间与时间戳的转换函数分享_javascript技巧

如果只是将当前时间转成时间戳,可以直接使用new Date().getTime()/1000:但如果是将某个具体时间或日期转成Unix时间戳,ie不支持像new Date("2013-1-1")  这样带参数的方法,将返回NaN. 对此,我写了以下函数,支持ie6+,谷歌,火狐等浏览器: 复制代码 代码如下: function getTime(day){  re = /(\d{4})(?:-(\d{1,2})(?:-(\d{1,2}))?)?(?:\s+(\d{1,2}):(\d{1,