0

也许任何人都可以帮助我解决这个问题。我只想选择两个日期之间的所有行,但是日期格式有问题。

我的查询:

SELECT id, number, date
FROM `table`
WHERE (STR_TO_DATE(date, '%j-%n-%Y') between '6-4-2015' AND '6-4-2016')

我不知道这个查询有什么问题。我试过使用STR_TO_DATEand DATE

日期的日期类型是文本(我想保留它)

下面是一个数据库示例:

1     233        5-4-2015
2     238        6-4-2015
3     431        7-4-2015
4     230        8-4-2015

有谁能够帮助我?

4

2 回答 2

1

请试试这个 strtotime 函数

'.date("d-m-Y", strtotime($r['date'])).'

例如

 "select * from sales3 where (sdate between '.date("d-m-Y", strtotime($r['date1'])).' and '.date("d-m-Y", strtotime($r['date2'])).')"
于 2015-04-29T08:45:12.097 回答
1

您在 中进行了错误的日期转换str_to_date,看起来日期是d-m-Y格式的,而您正在做的是

mysql> select STR_TO_DATE('5-4-2015', '%j-%n-%Y') ;
+-------------------------------------+
| STR_TO_DATE('5-4-2015', '%j-%n-%Y') |
+-------------------------------------+
| NULL                                |
+-------------------------------------+

所以它给你 null 并且商店在那里结束。

你应该使用

mysql> select STR_TO_DATE('5-4-2015', '%d-%m-%Y') ;
+-------------------------------------+
| STR_TO_DATE('5-4-2015', '%d-%m-%Y') |
+-------------------------------------+
| 2015-04-05                          |
+-------------------------------------+
1 row in set (0.00 sec)

现在比较应该是

WHERE 
STR_TO_DATE(date, '%d-%m-%Y') 
between 
STR_TO_DATE('6-4-2015','%d-%m-%Y') AND STR_TO_DATE('6-4-2015','%d-%m-%Y')
于 2015-04-29T08:53:14.753 回答