首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用mysql日期范围

使用mysql日期范围
EN

Stack Overflow用户
提问于 2013-11-02 19:04:41
回答 5查看 94关注 0票数 0

我试图使用以下查询从mysql数据库中检索基于特定日期范围的记录:

代码语言:javascript
复制
 $query = "SELECT * FROM data WHERE" .
          "date between '11/02/13' and '11/31/13' ";

我遇到的问题是,这个查询不基于年份进行区分。换句话说,它返回了2014年11月和2013年的记录。我确信这与我在mysql约会中缺乏知识有关,所以如果有人能为我指出正确的方向,我们会非常感激的!

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2013-11-02 19:10:28

将日期存储为varchar是不好的,但可以使用日期将字符串转换为日期。

代码语言:javascript
复制
SELECT * FROM data WHERE
STR_TO_DATE(`date`,'%m/%d/%y') between '11/02/13' and '11/31/13'

应激

票数 0
EN

Stack Overflow用户

发布于 2013-11-02 19:07:51

我想你必须把日期字符串转换成日期:

代码语言:javascript
复制
CAST('2003-01-01' AS DATE)
票数 0
EN

Stack Overflow用户

发布于 2013-11-02 19:11:09

代码语言:javascript
复制
SELECT * FROM data WHERE
          date between '11/02/13' and '11/31/13' GROUP BY YEAR(date)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19745704

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档