ホームページ > データベース > mysql チュートリアル > mysql数据库取得某一段时间内的纪录_MySQL

mysql数据库取得某一段时间内的纪录_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-01 13:34:49
オリジナル
1414 人が閲覧しました

bitsCN.com

mysql数据库取得某一段时间内的纪录

 

一般来说,我们在mysql数据库纪录数据时间时,都会选择datatime类型,这样时间可以精确到秒。但随之而来的一个问题是,当我们要取得某一段时间内的数据内容会有一些时间转换上的麻烦,例如我们要取得2002年3月2日到2003年7月8日的这段时间的内容,我们第一个直觉就是应该将sql写成下面的形式:

 

select * from yourdb where sj>='2002-3-2' and sj

 

 这样以来,我们取得数据内容就是2002年3月2日0点以后到2003年7月8日0点(也就是7月7号12点之前)之间的内容,这个当然不是我们想要的,所以需要使用mysql的时间函数to_days()来写这个sql:

 

select * from yourdb where to_days(sj)>=to_days('2002-3-2') and sj

 

 现在,我们所取得就是我们想要的结果了。

 

比如我要取这样的广告位 :广告位id为1,并且时间上前后限定;

 

select * from t_ads a where a.adsPosId = 1 and TO_DAYS(NOW()) >= TO_DAYS(a.beginDate)

and TO_DAYS(NOW()) bitsCN.com

関連ラベル:
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート