使用 MySQL 中的 DATE BETWEEN 检索多行

Retrieve multiple rows using DATE BETWEEN in MySQL

我有下面的 table 结构。

ID   |   FromDate   |    ToDate
1    |  2020-01-02  |  2020-06-01
2    |  2020-08-01  |  2020-12-01
3    |  2020-01-02  |  2020-11-28
4    |  2020-04-01  |  2020-05-28

当我传递2个名为fromDatetoDate的输入参数时,它应该select相关记录。

例如如果 FromDate = 2020-01-01ToDate = 2020-06-01,它应该 return ID 为 1 和 4 的记录,因为这两个记录在所提供参数的日期之间。

我目前正在使用下面的方法,感觉浪费了很多资源。

AND ToDate IN (select * from 
(select adddate('2000-01-01',t4.i*10000 + t3.i*1000 + t2.i*100 + t1.i*10 + t0.i) selected_date from
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 
union select 7 union select 8 union select 9) t0,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6                 union select 7 union select 8 union select 9) t1,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4) v
where selected_date between '2021-01-02 00:00:00' and '2022-03-02 00:00:00') ORDER BY name ASC,lt.ID ASC<code>

还有其他方法可以完成这个任务吗?

select * from table_name where fromDate>'2020-xx-xx' AND ToDate<'2020-xx-xx';

这种查询格式可以获取插入日期之间的记录