查看: 692|回复: 0

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

发表于 2017-11-22 08:00:13

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

  1. //其中 video 是表名;
  2. //createtime 是字段;
  3. //
  4. //数据库time字段为时间戳
  5. //
  6. //查询当天:
  7. $start = date('Y-m-d 00:00:00');
  8. $end = date('Y-m-d H:i:s');
  9. SELECT * FROM `table_name` WHERE `time` >= unix_timestamp( '$start' ) AND `time` <= unix_timestamp( '$end' )
  10. //查询本周:
  11. SELECT yearweek( '2011-04-17 15:38:22',1 ) //结果是201115
  12. SELECT yearweek( '2011-04-17 15:38:22' ) //结果是201116
  13. //yearweek的第2个参数设置为1的原因是,中国人习惯把周1作为本周的第一天
  14. //另外补充下:
  15. //2011-04-17 是周日。
  16. SELECT dayofweek( '2011-04-17 15:38:22' )// 查询出的是1,把礼拜天作为一周的第一天。
  17. SELECT dayofweek( '2011-04-18 15:38:22' ) //查询出的是2
  18. SELECT weekday( '2011-04-17 15:38:22' )// 查询出的是6,
  19. SELECT weekday( '2011-04-18 15:38:22' )// 查询出的是0,
  20. //所以建议使用weekday,查询出来的结果+1就可以了,就比较符合国人的习惯了。
  21. SELECT * FROM `table_name` WHERE YEARWEEK( FROM_UNIXTIME( `time`, '%Y-%m-%d %H:%i:%s' ) ,1) = YEARWEEK( now( ),1 )
  22. //查询本月:
  23. $start = date('Y-m-01 00:00:00');
  24. $end = date('Y-m-d H:i:s');
  25. SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('”.$start.”') AND `time` <= unix_timestamp('$end')
  26. //查询本年:
  27. $start = date('Y-01-01 00:00:00');
  28. $end = date('Y-m-d H:i:s');
  29. SELECT * FROM `table_name` WHERE `time` >= unix_timestamp( '$start' ) AND `time` <= unix_timestamp( '$end' )
复制代码

php 获取今日、昨日、上周、本月的起始时间戳和结束时间

  1. <?php
  2. //<!--php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法,主要使用到了 php 的时间函数 mktime()。-->
  3. //1、php获取今日开始时间戳和结束时间戳
  4. $beginToday = mktime(0,0,0,date('m'),date('d'),date('Y'));
  5. $endToday = mktime(0,0,0,date('m'),date('d')+1,date('Y'))-1;
  6. echo $beginToday.'---'.$endToday;
  7. echo '<br/>';
  8. //2、php获取昨日起始时间戳和结束时间戳
  9. $beginYesterday = mktime(0,0,0,date('m'),date('d')-1,date('Y'));
  10. $endYesterday = mktime(0,0,0,date('m'),date('d'),date('Y'))-1;
  11. echo $beginYesterday.'---'.$endYesterday;
  12. echo '<br/>';
  13. //3、php获取上周起始时间戳和结束时间戳
  14. $beginLastweek=mktime(0,0,0,date('m'),date('d')-date('w')+1-7,date('Y'));
  15. $endLastweek=mktime(23,59,59,date('m'),date('d')-date('w')+7-7,date('Y'));
  16. echo $beginLastweek.'---'.$endLastweek;
  17. echo '<br/>';
  18. //4、php获取本月起始时间戳和结束时间戳
  19. $beginThismonth=mktime(0,0,0,date('m'),1,date('Y'));
  20. $endThismonth=mktime(23,59,59,date('m'),date('t'),date('Y'));
  21. echo $beginThismonth.'---'.$endThismonth;
  22. echo '<br/>';
  23. //PHP mktime() 函数用于返回一个日期的 Unix 时间戳。
  24. //语法:mktime(hour,minute,second,month,day,year,is_dst)
  25. //
  26. //参数 描述
  27. //hour 可选。规定小时。
  28. //minute 可选。规定分钟。
  29. //second 可选。规定秒。
  30. //month 可选。规定用数字表示的月。
  31. //day 可选。规定天。
  32. //year 可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。
  33. //is_dst可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。
  34. //自 5.1.0 起,is_dst 参数被废弃。因此应该使用新的时区处理特性。参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。
  35. //
  36. //参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。
  37. echo(date("M-d-Y",mktime(0,0,0,12,36,2001)));
  38. //将输出结果如:
  39. //
  40. //Jan-05-2002
复制代码

以上这篇php、mysql查询当天,查询本周,查询本月的数据实例(字段是时间戳)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持程序员之家。



回复

使用道具 举报

关闭

站长推荐上一条 /1 下一条