|
|
|
| Задана таблица tablename:
+--------+--------+
| begin | end |
+--------+--------+
| 15 | 21 |
| 10 | 22 |
| 8 | 17 |
| 1 | 10 |
+--------+--------+
Нужно выбрать ОДНУ строку, которая соответствует условию:
begin =< мое_число =< end и минимум(end - begin).
Т.е. если мое_число = 15, то результат: 1-я строка.
Подскажите, плз., как это сделать на языке MySQL?
select * from tablename where 15 between tablename.begin and tablename.end
НЕ ПОДХОДИТ, т.к. выбирает 1, 2 и 3 строки. А мне нужно первую строку, где значение end минус begin МИНИМАЛЬНО, т.е. MIN(end-begin).
Спасибо. | |
|
|
|
|
|
|
|
для: Brat-2
(04.03.2006 в 19:46)
| | select не всё
а select min(end - begin)
select min(end - begin) from tablename where 15 between tablename.begin and tablename.end | |
|
|
|
|
|
|
|
для: Himic
(04.03.2006 в 20:45)
| | возвращает просто значение 6, т.е. 21-15. А мне нужны значения 15 и 21. | |
|
|
|
|
|
|
|
для: Brat-2
(04.03.2006 в 19:46)
| | Ограничить число выводимых строк можно при помощи конструкции LIMIT, но запрос
select * from tablename where 15 between tablename.begin and tablename.end LIMIT 1
|
не подходит, так как он выводит не то, что вам нужно и результат совпадает с желаемым случайно. Можно воспользоваться запросом
SELECT MIN(end - begin) FROM tbl
|
если сразу требуется разница. | |
|
|
|