本文主要为广大网友提供“mysql 查询指定日期时间内sql语句实现原理与代码”,希望对需要mysql 查询指定日期时间内sql语句实现原理与代码网友有所帮助,学习一下!
在数据库教程设计时必须注意时间字段为int(11)这样,保存在数据库的是一个数字型日期时间戳,我们可以用mktime函数求出当前日期的时间戳进行加减就OK了,下面看实例
//一个月
复制代码 代码如下:
$lastMonth = mktime(date(‘h''),date(‘i''),date(‘s''),date(‘m'')-1,date(‘d''),date(‘y''));
$where .= ” dtime > $lastMonth”;
//三个月
复制代码 代码如下:
$lastThreeMonth = mktime(date(‘h''),date(‘i''),date(‘s''),date(‘m'')-3,date(‘d''),date(‘y''));
$where .= ” dtime > $lastThreeMonth”;
$sql = “select * from testtable ” .$where
/*
原理是:
如果是月份就是当前的月减去你要统计的时间如我要
查询数据库中从今天起往前三个月的所有记录,我们的语句如下:mktime(date(‘h''),date(‘i''),date(‘s''),date(‘m'')-3,date(‘d''),date(‘y''));
七天内的:mktime(date(‘h''),date(‘i''),date(‘s''),date(‘m''),date(‘d'')-7,date(‘y''));
一小时间内的:mktime(date(‘h'')-1,date(‘i''),date(‘s''),date(‘m''),date(‘d''),date(‘y''));
上个月第一天:mktime(0,0,0,date(‘m'')-1,01,date(‘Y''));
上个月最后一天:mktime(0,0,0,date(‘m''),0,date(‘y''));
本月第一天:这个简单,也就是01了;
本月最后一天:这要用到date函数了,date函数有一个参数t,它就是用来求最后一天的;如:date(‘t'')
其它的做法是一样的。