mysql中UNIX_TIMESTAMP(),FROM_TIMESTAMP,YEAR(),HOUR(),minute(),second()函数的使用!
来源:互联网 发布:大数据需要学java吗 编辑:程序博客网 时间:2024/05/20 13:04
mysql 中:UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date)
若无参数调用,则返回一个 Unix timestamp ('1970-01-01 00:00:00' GMT 之后的秒数) 作为无符号整数。若用date 来调用 UNIX_TIMESTAMP(),它会将参数值以'1970-01-01 00:00:00' GMT后的秒数的形式返回。date 可以是一个 DATE 字符串、一个 DATETIME字符串、一个 TIMESTAMP或一个当地时间的YYMMDD 或YYYMMDD格式的数字。
mysql> Select UNIX_TIMESTAMP();
-> 882226357
mysql> Select UNIX_TIMESTAMP('1997-10-04 22: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-DD HH:MM:SS'或YYYYMMDDHHMMSS 格式值的 unix_timestamp参数表示,具体格式取决于该函数是否用在字符串中或是数字语境中。
若format 已经给出,则结果的格式是根据format 字符串而定。 format 可以包含同DATE_FORMAT() 函数输入项列表中相同的说明符。
mysql> Select FROM_UNIXTIME(875996580);
-> '1997-10-04 22:23:00'
mysql> Select FROM_UNIXTIME(875996580) + 0;
-> 19971004222300
mysql> Select FROM_UNIXTIME(UNIX_TIMESTAMP(),
-> '%Y %D %M %h:%i:%s %x');
-> '2003 6th August 06:22:58 2003'
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()函数!
mysql> select FROM_UNIXTIME( 1286219870 ,'%Y-%m-%d %h:%i:%s' );
+--------------------------------------------------+
| FROM_UNIXTIME( 1286219870 ,'%Y-%m-%d %h:%i:%s' ) |
+--------------------------------------------------+
| 2010-10-05 03:17:50 |
+--------------------------------------------------+
1 row in set (0.00 sec)
mysql> select FROM_UNIXTIME( 1286219871 ,'%Y-%m-%d %h:%i:%s' );
+--------------------------------------------------+
| FROM_UNIXTIME( 1286219871 ,'%Y-%m-%d %h:%i:%s' ) |
+--------------------------------------------------+
| 2010-10-05 03:17:51 |
+--------------------------------------------------+
1 row in set (0.00 sec)
mysql> select FROM_UNIXTIME( 1286219871 ,'%Y-%m-%d %h:%i:%s' );
mysql> SELECT year(curdate());
+-----------------+
| year(curdate()) |
+-----------------+
| 2011 |
+-----------------+
1 row in set (0.00 sec)
mysql> SELECT year(2011-01-17 11:39:14);
ERROR 1064 (42000): You have an error in your SQL syn
corresponds to your MySQL server version for the righ
:14)' at line 1
mysql> SELECT year('2011-01-17 11:39:14');
+-----------------------------+
| year('2011-01-17 11:39:14') |
+-----------------------------+
| 2011 |
+-----------------------------+
1 row in set (0.00 sec)
mysql> SELECT hour('2011-01-17 11:39:14');
+-----------------------------+
| hour('2011-01-17 11:39:14') |
+-----------------------------+
| 11 |
+-----------------------------+
1 row in set (0.00 sec)
mysql> SELECT mounth('2011-01-17 11:39:14');
ERROR 1046 (3D000): No database selected
mysql> SELECT month('2011-01-17 11:39:14');
+------------------------------+
| month('2011-01-17 11:39:14') |
+------------------------------+
| 1 |
+------------------------------+
1 row in set (0.00 sec)
mysql> SELECT minute('2011-01-17 11:39:14');
+-------------------------------+
| minute('2011-01-17 11:39:14') |
+-------------------------------+
| 39 |
+-------------------------------+
1 row in set (0.00 sec)
mysql> SELECT second('2011-01-17 11:39:14');
+-------------------------------+
| second('2011-01-17 11:39:14') |
+-------------------------------+
| 14 |
+-------------------------------+
1 row in set (0.00 sec)
mysql> SELECT MICROSECOND('12:00:00:123456');
+--------------------------------+
| MICROSECOND('12:00:00:123456') |
+--------------------------------+
| 0 |
+--------------------------------+
1 row in set, 1 warning (0.00 sec)
mysql> SELECT MICROSECOND('12:00:00.123456');
+--------------------------------+
| MICROSECOND('12:00:00.123456') |
+--------------------------------+
| 123456 |
+--------------------------------+
1 row in set (0.00 sec)
- mysql中UNIX_TIMESTAMP(),FROM_TIMESTAMP,YEAR(),HOUR(),minute(),second()函数的使用!
- MySQL的unix_timestamp()函数
- 设计一个时间类Time,要求: (1)包含时(hour)、分(minute)和秒(second)私有数据成员。 (2)包含构造函数,重载关于一时间加上另一时间的加法运算符+、重载关于一时间减去另一时间
- MySQL查询中时间转换--UNIX_TIMESTAMP()和from_unixtime()的使用
- Excel计算时间 活用 HOUR和MINUTE函数。计算出两个单元格的差,是几个小时
- MySQL中的UNIX_TIMESTAMP函数使用总结
- MySQL中的UNIX_TIMESTAMP函数使用总结 :
- MySQL中的UNIX_TIMESTAMP函数使用总结
- MySQL中的UNIX_TIMESTAMP函数使用总结
- MySQL中的UNIX_TIMESTAMP函数使用总结
- MySQL 5.5中使用UNIX_TIMESTAMP分区
- MySQL的FROM_UNIXTIME()和UNIX_TIMESTAMP()函数
- mysql中的unix_timestamp函数
- mysql中的unix_timestamp函数
- mysql中的unix_timestamp函数
- sql 将秒数转换为小时:分:秒 Convert seconds to Hour:Minute:Second
- mysql中UNIX_TIMESTAMP()函数和php中time()函数的区别
- mysql中UNIX_TIMESTAMP()函数和php中time()函数的区别
- MGCP 什么是lockstep状态
- 关于 try/catch
- ORACLE 10G修改归档目录方法
- python类型数值操作
- iphone开发--获取系统配置文件内容
- mysql中UNIX_TIMESTAMP(),FROM_TIMESTAMP,YEAR(),HOUR(),minute(),second()函数的使用!
- Win7才是半成品,从技术角度看Win8之进化
- 计算机网络---第二章 数据通信技术
- 修改oracle日志文件大小
- 接口功能测试策略
- 客户端接收组件的错误信息
- ossec开源入侵检测系统安装配置
- jq上传的值出现部分乱码
- Android 下载SDK 和 升级SDK方法 查看android源码