Chinaunix首页 | 论坛 | 博客
  • 博客访问: 172691
  • 博文数量: 40
  • 博客积分: 888
  • 博客等级: 准尉
  • 技术积分: 396
  • 用 户 组: 普通用户
  • 注册时间: 2010-09-01 10:17
文章分类
文章存档

2013年(10)

2012年(10)

2011年(11)

2010年(9)

分类: LINUX

2011-05-12 13:00:49

mysql中UNIX_TIMESTAMP()函数的应用比较(2009-09-10 10:11:55)
var $tag='杂谈'; var $tag_code='d0dadf31d280cae73f8f48959ee1d803'; var $r_quote_bligid='5f7b8c2c0100fgjj'; var $worldcup='0'; var $worldcupball='0'; 标签: 杂谈 分类: MySQL常识

应用:SELECT (

UNIX_TIMESTAMP( endtime ) - UNIX_TIMESTAMP( startime )

) /31536000year, id, name
FROM testime
LIMIT 0 , 30

 常用作数据表中两时间的比较

下面对这两个函数作比较好记忆:

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()函数!

希望大家用的开心!

 

from_unixtime()是MySQL里的时间函数
date为需要处理的参数(该参数是Unix 时间戳),可以是字段名,也可以直接是Unix 时间戳字符串
后面的 '%Y%m%d' 主要是将返回值格式化
例如:
mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y%m%d' )  
->20071120
mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y年%m月%d' )
->2007年11月20
UNIX_TIMESTAMP() 是与之相对正好相反的时间函数

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() ; (执行使得时间:2009-08-06 10:10:40)
->1249524739
mysql> SELECT UNIX_TIMESTAMP('2009-08-06') ;
->1249488000

SELECT *
FROM `student`
WHERE regTime > UNIX_TIMESTAMP( curdate( ) ) //
今天所有学生注册记录
 
 
 
if ($ != jQuery) { $ = jQuery.noConflict(); } var isLogined = false; var cb_blogId = 18300; var cb_entryId = 1689054; var cb_blogApp = "showker"; var cb_blogUserGuid = "e353360b-63cf-dd11-9e4d-001cf0cd104b"; var cb_entryCreatedDate = '2010/3/18 16:12:00';
阅读(1686) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~