Bạn có thể làm điều gì đó tương tự với tham gia:
select * from table a
inner join (
select id,
max(
if(`date` <= __LOWERLIMIT__ ,`date`, 0)
) as min_date,
min(
if(`date` >= __UPPERLIMIT__ , `date`, UNIX_TIMESTAMP())
) as max_date
from table
where id = __ID__
group by id
) range on
range.id = a.id and
a.`date` between min_date and max_date;
Tôi không phải là chuyên gia về MySQL, vì vậy, xin lỗi nếu cần chỉnh sửa một chút về cú pháp.
Cập nhật: OP cũng đã tìm thấy giải pháp rất hay này .