MySQL 使用 DD-MM-YYYY 日期格式过滤记录集

标签 mysql date filter format

我对如何按日期格式过滤记录有点困惑。

我在日期表中有日期(yyyy-mm-dd)数据类型的日期列。

例如:

date
-----
2017-01-29
2017-01-30

我想更改格式 (dd-mm-yyyy)。我正在使用此代码

SELECT 
   DATE_FORMAT(`date`, '%d-%m-%Y') as date
FROM
    dim_date;

date
-----
29-01-2017
30-01-2017

我想用(dd-mm-yyyy)格式过滤记录。所以我尝试了这段代码。

SELECT 
   DATE_FORMAT(`date`, '%d-%m-%Y') date
FROM
    dim_date
WHERE DATE_FORMAT(`date`, '%d-%m-%Y') BETWEEN '20-04-2015' AND '06-09-2017';

结果 什么都没有

但是如果我尝试使用原始格式(yyyy-mm-dd)进行过滤,它就可以了。

SELECT DATE_FORMAT(`date`, '%d-%m-%Y') date
FROM dim_date
WHERE DATE_FORMAT(`date`, '%Y-%m-%d') BETWEEN '2015-04-20' AND '2017-01-07';

为什么 Mysql 中有这种奇怪的行为?我在这里遗漏了什么吗?

我也尝试过使用这种格式 DATE_FORMAT(date, '%d-%c-%Y') , DATE_FORMAT(date, '%d-%l-%Y') & DATE_FORMAT(日期, '%e-%l-%Y') 没有高兴的表情,请告诉我。

谢谢

最大

最佳答案

通过您的查询,您将日期转换为字符串,然后您以错误的顺序( '20' > '06' )比较值,因此不起作用。 首先要求最小值,其次要求最大值。

如果您正在使用日期,则需要转换字符串日期
所以正确工作和避免字符串行为之间的关系是过滤器

SELECT date 
FROM dim_date
WHERE date   BETWEEN str_to_dat('20-04-2015', '%d-%m-%Y') 
            AND str_to_date('06-09-2017', '%d-%,-%Y');

关于MySQL 使用 DD-MM-YYYY 日期格式过滤记录集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46431760/

相关文章:

MySQL AND 关键字问题

sql - IBM DB2 SQL | IBM DB2 SQL从年份和周数获取星期日和星期一日期

Excel:计算自动过滤表中单元格和单元格之间的差异

javascript - 我如何在 React 中对我的数据进行多个过滤器?

mysql - 如何在另一个表中显示一个表中的列

mysql - DATEDIFF 与 DATE 比较 MySQL 中的日期

php - Mysql select 查询性能变差

php - 从按日期命名的多个表中选择一个范围

php - 检查字符串是否为日期的函数

html - 根据子元素的内容为父元素编写ublock过滤规则