php、mysql查詢當天,查詢本周,查詢本月的數據實例(字段是時間戳)


php、mysql查詢當天,查詢本周,查詢本月的數據實例(字段是時間戳)

 

    //其中 video 是表名;
    //createtime 是字段;
    //
    //數據庫time字段為時間戳
    //
    //查詢當天:

    $start = date('Y-m-d 00:00:00');
    $end = date('Y-m-d H:i:s');
    SELECT * FROM `table_name` WHERE `time` >= unix_timestamp( '$start' ) AND `time` <= unix_timestamp( '$end' )

    //查詢本周:

    SELECT yearweek( '2011-04-17 15:38:22',1 ) //結果是201115
    SELECT yearweek( '2011-04-17 15:38:22' ) //結果是201116
    //yearweek的第2個參數設置為1的原因是,中國人習慣把周1作為本周的第一天
    //另外補充下:
    //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');
    SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('".$start."') AND `time` <= unix_timestamp('$end')

    //查詢本年:

    $start = date('Y-01-01 00:00:00');
    $end = date('Y-m-d H:i:s');
    SELECT * FROM `table_name` WHERE `time` >= unix_timestamp( '$start' ) AND `time` <= unix_timestamp( '$end' )

php 獲取今日、昨日、上周、本月的起始時間戳和結束時間

 

<?php
    //<!--php 獲取今日、昨日、上周、本月的起始時間戳和結束時間戳的方法,主要使用到了 php 的時間函數 mktime()。-->

    //1、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;

    echo $beginToday.'---'.$endToday;
    echo '<br/>';
    //2、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;

    echo $beginYesterday.'---'.$endYesterday;
    echo '<br/>';
    //3、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'));

    echo $beginLastweek.'---'.$endLastweek;
    echo '<br/>';

    //4、php獲取本月起始時間戳和結束時間戳

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

    echo $beginThismonth.'---'.$endThismonth;
    echo '<br/>';

    //PHP mktime() 函數用於返回一個日期的 Unix 時間戳。
    //語法:mktime(hour,minute,second,month,day,year,is_dst)
    //
    //參數    描述
    //hour    可選。規定小時。
    //minute    可選。規定分鍾。
    //second    可選。規定秒。
    //month    可選。規定用數字表示的月。
    //day    可選。規定天。
    //year    可選。規定年。在某些系統上,合法值介於 1901 - 2038 之間。不過在 PHP 5 中已經不存在這個限制了。
    //is_dst可選。如果時間在日光節約時間(DST)期間,則設置為1,否則設置為0,若未知,則設置為-1。
    //自 5.1.0 起,is_dst 參數被廢棄。因此應該使用新的時區處理特性。參數總是表示 GMT 日期,因此 is_dst 對結果沒有影響。
    //
    //參數可以從右到左依次空着,空着的參數會被設為相應的當前 GMT 值。

    echo(date("M-d-Y",mktime(0,0,0,12,36,2001)));

    //將輸出結果如:
    //
    //Jan-05-2002

 自己實踐

<?php

    $conn = mysqli_connect("localhost","root","spirit","honeypot") or die("error in connection");
    
    // total
    $query = mysqli_query($conn, "SELECT count(*) FROM awshoneypot");
    $count = mysqli_fetch_array($query);
    echo number_format($count[0],0,".",",");
    echo "</br>";
    
    // daily
    $beginToday = date('Y-m-d 00:00:00');
    $endToday = date('Y-m-d 23:59:59');
    $query1 = mysqli_query($conn, "SELECT count(*) FROM awshoneypot WHERE datetime >= '$beginToday' AND datetime <= '$endToday' ");
    $count1 = mysqli_fetch_array($query1);
    echo number_format($count1[0],0,".",",");
    echo "</br>";
    
    // weekly
    $beginWeek = date("Y-m-d 00:00:00",mktime(0,0,0,date('m'),date('d')-date('w')+1-3,date('Y')));
    $endWeek = date('Y-m-d 23:59:59');
    $query2 = mysqli_query($conn, "SELECT count(*) FROM awshoneypot WHERE datetime >= '$beginWeek' AND datetime <= '$endWeek' ");
    $count2 = mysqli_fetch_array($query2);
    echo number_format($count2[0],0,".",",");
    echo "</br>";
    
    // monthly
    $beginMonth=date("Y-m-d 00:00:00", mktime(0,0,0,date('m'),1,date('Y')));
    $endMonth= date('Y-m-d 23:59:59');
    $query3 = mysqli_query($conn, "SELECT count(*) FROM awshoneypot WHERE datetime >= '$beginMonth' AND datetime <= '$endMonth' ");
    $count3 = mysqli_fetch_array($query3);
    echo number_format($count3[0],0,".",",");
    echo "</br>";

?>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM