首页 > 解决方案 > 在 MySQL 中使用 mm/dd/yyyy 格式选择数据

问题描述

我有下表结构。

Tax      |   FromDate    |   EndDate
12.32    |   12-29-2020  |   12-29-2021

税率 12.32 的有效期为FromDateEndDateFromDate指定介于和之间的日期范围时应选择 12.32 EndDate

@startdate我尝试了以下查询,但是通过and时它没有给我有效的输出@enddate

SELECT Tax
FROM Table
WHERE
  DATE_FORMAT(@startDate, '%m-%d-%y') >= DATE_FORMAT(t.fromDate, '%m-%d-%y')
  AND DATE_FORMAT(@endDate, '%m-%d-%y') <=  DATE_FORMAT(t.endDate, '%m-%d-%y')  LIMIT 1;

目前,我使用 VARCHAR(45) 作为列的 DataType 以及输入参数值的 DataType。我选择了 VARCHAR(45),因为在处理 mm-dd-yyyy 时使用 DATE 类型会引发错误。

我哪里出错了?

下面是示例代码。

SET @startDate = '07-29-2019';
SET @endDate = '09-29-2019';

DROP TEMPORARY TABLE IF EXISTS Dates;
CREATE TEMPORARY TABLE Dates (StartDate VARCHAR(20),EndDate VARCHAR(20),Tax INT);
INSERT INTO Dates VALUES ('06-29-2019','06-29-2020',1);

SELECT *
FROM Dates
WHERE
STR_TO_DATE(@startDate, '%m-%d-%y') <= STR_TO_DATE(EndDate, '%m-%d-%y')
AND STR_TO_DATE(@endDate, '%m-%d-%y') >= STR_TO_DATE(StartDate, '%m-%d-%y')

根据上面的代码,它应该返回一行。但它不回来了。

标签: mysqlsqldatewhere-clausedate-format

解决方案


你想要STR_TO_DATE(),没有DATE_FORMAT()。后者将日期转换为给定的字符串格式,而前者将格式化的日期字符串转换为日期(据我了解,您的问题是您要查找的内容):

SELECT Tax
FROM Table
WHERE
  STR_TO_DATE(@startDate, '%m-%d-%Y') >= STR_TO_DATE(t.fromDate, '%m-%d-%Y')
  AND STR_TO_DATE(@endDate, '%m-%d-%Y') <=  STR_TO_DATE(t.endDate, '%m-%d-%Y')  
ORDER BY ?
LIMIT 1;

请注意,您应该ORDER BY在查询中添加一个子句,这样LIMIT才有意义(否则,如果谓词允许多行,则未定义将返回哪一行)。

我也不确定该WHERE条款。如果您想要在给定日期范围参数内有效的税款,则应为:

WHERE
  STR_TO_DATE(@startDate, '%m-%d-%Y') <= STR_TO_DATE(t.endDate, '%m-%d-%Y')
  AND STR_TO_DATE(@endDate, '%m-%d-%Y') >= STR_TO_DATE(t.startDate, '%m-%d-%Y')

推荐阅读