php、mysql查询当天,查询本周,查询本月的数据实例

四月 05, 2019 | views
Comments 0

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

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

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

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



zend