【发布时间】:2012-11-09 11:55:33
【问题描述】:
我有以下查询,该查询通常有效,并且应该返回涵盖定义时间范围的所有行(如果没有绝对匹配,则取最接近的前一行和下一行 - 概述于 http://www.orafaq.com/node/1834)
SELECT * FROM table
WHERE id=__ID__ AND `date` BETWEEN
IFNULL((SELECT MAX(`date`) FROM table WHERE id=__ID__ AND `date`<=__LOWERLIMIT__), 0)
AND
IFNULL((SELECT MIN(`date`) FROM table WHERE id=__ID__ AND `date`>=__UPPERLIMIT__), UNIX_TIMESTAMP())
ORDER BY `date`
但希望通过引用外部选择来减少两个表子选择,但显然它不喜欢它
SELECT * FROM (SELECT * FROM table WHERE id=__ID__) b
WHERE `date` BETWEEN
IFNULL((SELECT MAX(`date`) FROM b WHERE `date`<=__LOWERLIMIT__), 0)
AND
IFNULL((SELECT MIN(`date`) FROM b WHERE `date`>=__UPPERLIMIT__), UNIX_TIMESTAMP())
ORDER BY `date`
有没有办法在不选择三个表的情况下进行查询?
【问题讨论】: