mysql - 在 MySQL 中使用 mm/dd/yyyy 格式选择数据
问题描述
我有下表结构。
Tax | FromDate | EndDate
12.32 | 12-29-2020 | 12-29-2021
税率 12.32 的有效期为FromDate
至EndDate
。FromDate
指定介于和之间的日期范围时应选择 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')
根据上面的代码,它应该返回一行。但它不回来了。
解决方案
你想要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')
推荐阅读
- javascript - 使用 JavaScript 函数将文本转换为图像,然后将图像转换为文本,以消除像“”到“This”这样的字体字符
- php - 具有默认值的 Laravel 条件顺风类
- python - np.busday_count 与 NaT
- javascript - 刷新页面后,我退出了吗?为什么?
- javascript - Javascript:更改相对路径将无法打开网址
- java - 着色字符串的指定字符
- javascript - 相当于 Underscore.js 中的 Lodash _.set()
- sql - 使用 Groovy 或 Gradle 应用现有的 SQL 模式
- javascript - 一个项目文件夹下有多个 NextJS 子项目?
- ethereum - 如何获得测试帐户以使用松露部署智能合约?