//php获取昨日起始时间戳和结束时间戳,php、my
分类:美高梅网上注册平台

复制代码 代码如下:
美高梅网上注册平台 ,//php获取今日开始时间戳和结束时间戳
$beginToday=mktime(0,0,0,date('m'),date('d'),date('Y'));
$endToday=mktime(0,0,0,date('m'),date('d')+1,date('Y'))-1;

下面我们开始介绍如何获取当天的开始时间截和结束时间截。 代码如下:

php、mysql查询当天,查询本周,查询本月的数据实例(字段是时间戳)

//php获取昨日起始时间戳和结束时间戳

mktime(hour,minute,second,month,day,year,is_dst)

 代码如下

$beginYesterday=mktime(0,0,0,date('m'),date('d')-1,date('Y'));
$endYesterday=mktime(0,0,0,date('m'),date('d'),date('Y'))-1;

参数 描述
hour 可选。规定小时。
minute 可选。规定分钟。
second 可选。规定秒。
month 可选。规定用数字表示的月。
day 可选。规定天。
year 可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。
is_dst
可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。

//其中 video 是表名;

//php获取上周起始时间戳和结束时间戳

例子 今日、昨日、上周、本月的起始时间戳和结束时间戳

//createtime 是字段;

$beginLastweek=mktime(0,0,0,date('m'),date('d')-date('w')+1-7,date('Y'));
$endLastweek=mktime(23,59,59,date('m'),date('d')-date('w')+7-7,date('Y'));

 代码如下

//

//php获取本月起始时间戳和结束时间戳

//开始时间截

//数据库time字段为时间戳

$beginThismonth=mktime(0,0,0,date('m'),1,date('Y'));
$endThismonth=mktime(23,59,59,date('m'),date('t'),date('Y'));

$start=mktime(0,0,0,date("m"),date("d"),date("Y"));

//

PHP mktime() 函数用于返回一个日期的 Unix 时间戳。

//结束时间截:
$end=mktime(0,0,0,date('m'),date('d')+1,date('Y'))-1;

//查询当天:

语法

//php获取昨日起始时间戳和结束时间戳
 
$beginYesterday=mktime(0,0,0,date('m'),date('d')-1,date('Y'));
 
$endYesterday=mktime(0,0,0,date('m'),date('d'),date('Y'))-1;
 
//php获取上周起始时间戳和结束时间戳
 
$beginLastweek=mktime(0,0,0,date('m'),date('d')-date('w')+1-7,date('Y'));
 
$endLastweek=mktime(23,59,59,date('m'),date('d')-date('w')+7-7,date('Y'));
 
//php获取本月起始时间戳和结束时间戳
 
$beginThismonth=mktime(0,0,0,date('m'),1,date('Y'));
 
$endThismonth=mktime(23,59,59,date('m'),date('t'),date('Y'));

 

mktime(hour,minute,second,month,day,year,is_dst)

写成函数转换成中文

$start=date('Y-m-d 00:00:00');

参数 描述
hour 可选。规定小时。
minute 可选。规定分钟。
second 可选。规定秒。
month 可选。规定用数字表示的月。
day 可选。规定天。
year 可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。
is_dst
可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。

 代码如下

$end=date('Y-m-d H:i:s');

自 5.1.0 起,is_dst 参数被废弃。因此应该使用新的时区处理特性。

function get_period_time($type='day'){
    $rs = FALSE;
    $now = time();
    switch ($type){
        case 'day'://今天
            $rs['beginTime'] = date('Y-m-d 00:00:00', $now);
            $rs['endTime'] = date('Y-m-d 23:59:59', $now);
            break;
        case 'week'://本周
            $time = '1' == date('w') ? strtotime('Monday', $now) : strtotime('last Monday', $now);
            $rs['beginTime'] = date('Y-m-d 00:00:00', $time);
            $rs['endTime'] = date('Y-m-d 23:59:59', strtotime('Sunday', $now));
            break;
        case 'month'://本月
            $rs['beginTime'] = date('Y-m-d 00:00:00', mktime(0, 0, 0, date('m', $now), '1', date('Y', $now)));
            $rs['endTime'] = date('Y-m-d 23:39:59', mktime(0, 0, 0, date('m', $now), date('t', $now), date('Y', $now)));
            break;
        case '3month'://三个月
            $time = strtotime('-2 month', $now);
            $rs['beginTime'] = date('Y-m-d 00:00:00', mktime(0, 0,0, date('m', $time), 1, date('Y', $time)));
            $rs['endTime'] = date('Y-m-d 23:39:59', mktime(0, 0, 0, date('m', $now), date('t', $now), date('Y', $now)));
            break;
        case 'half_year'://半年内
            $time = strtotime('-5 month', $now);
            $rs['beginTime'] = date('Y-m-d 00:00:00', mktime(0, 0,0, date('m', $time), 1, date('Y', $time)));
            $rs['endTime'] = date('Y-m-d 23:39:59', mktime(0, 0, 0, date('m', $now), date('t', $now), date('Y', $now)));
            break;
        case 'year'://今年内
            $rs['beginTime'] = date('Y-m-d 00:00:00', mktime(0, 0,0, 1, 1, date('Y', $now)));
            $rs['endTime'] = date('Y-m-d 23:39:59', mktime(0, 0, 0, 12, 31, date('Y', $now)));
            break;
    }
    return $rs;
}

SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('$start') AND `time` <= unix_timestamp('$end')

用法

 

参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。

//查询本周:

参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。

 

注意在 PHP 5.1 之前,如果该函数的参数非法,则会返回 false。

SELECT yearweek('2011-04-17 15:38:22',1 )//结果是201115

另外需要注意的是该函数对于日期运算和验证非常有用。它可以自动校正越界的输入,如:

SELECT yearweek('2011-04-17 15:38:22')//结果是201116

复制代码 代码如下:
echo(date("M-d-Y",mktime(0,0,0,12,36,2013)));

//yearweek的第2个参数设置为1的原因是,中国人习惯把周1作为本周的第一天

将输出结果如:Jan-05-2014

//另外补充下:

//2011-04-17 是周日。

SELECT dayofweek('2011-04-17 15:38:22')// 查询出的是1,把礼拜天作为一周的第一天。

SELECT dayofweek('2011-04-18 15:38:22')//查询出的是2

SELECT weekday('2011-04-17 15:38:22')// 查询出的是6,

SELECT weekday('2011-04-18 15:38:22')// 查询出的是0,

//所以建议使用weekday,查询出来的结果+1就可以了,就比较符合国人的习惯了。

 

SELECT * FROM `table_name` WHERE YEARWEEK( FROM_UNIXTIME( `time`,'%Y-%m-%d %H:%i:%s') ,1) = YEARWEEK( now( ),1 )

 

//查询本月:

 

$start=date('Y-m-01 00:00:00');

$end=date('Y-m-d H:i:s');

本文由美高梅网上注册平台发布于美高梅网上注册平台,转载请注明出处://php获取昨日起始时间戳和结束时间戳,php、my

上一篇:pid为父分类 下一篇:验证日期的正确性
猜你喜欢
热门排行
精彩图文