Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.10.10;
Скачать: CL | DM;

Вниз

?SQL   Найти похожие ветки 

 
PrettyFly   (2002-09-18 17:45) [0]

Есть такая задача:
Дана таблица с integerами (>0), нужно
найти минимальный integer >0, который
не встречается в этой таблице...
(всё это в InterBase 5)

CREATE PROCEDURE GetMinNumber
RETURNS (MinNumber INTEGER)
AS
BEGIN
MinNumber = 1;
WHILE (MinNumber IN (SELECT Number FROM OurTable))
DO MinNumber = MinNumber + 1;
END


почему такая процедурка выдаёт ошибку
"subselect illegal in this context"
и как тогда лучше сделать?


 
Андрей Прокофьев   (2002-09-18 17:55) [1]

Может, найти минимальный, который встречается и отнять 1


 
Андрей Прокофьев   (2002-09-18 17:57) [2]

Извините, невнимательно прочел и вообще не подумал :(


 
ЮЮ ©   (2002-09-19 03:21) [3]

Может лучше пробежаться по одному запросу к таблице, сравнивая Number текущей записи с PriorNumber, запомненым при просмотре предыдущей записи, и если Number-PriorNumber>1 возвращать PriorNumber+1, чем выполнять новый запрос в цикле


 
SVM   (2002-09-19 08:41) [4]

Еще вариант:

1. Найти минимальное значение поля (ID).
Если это значение >1, то искомое значение
на 1 меньше. Иначе выполнить запрос:

2. select a.ID+1 as aID,
b.id as bID from T a Left Join T b
on a.id=b.id-1 where b.ID is null order by 1

Первая строка будет содержать требуемое значение.


 
PrettyFly   (2002-09-19 13:33) [5]

Спасиба за идею...


 
Johnmen ©   (2002-09-19 15:03) [6]

Проанализировав идею SVM (19.09.02 08:41),
можно получить сразу то, что надо, так :

SELECT 1 AS Fld FROM Tbl
WHERE 1<(SELECT MIN(id) FROM Tbl)
UNION
SELECT A.id+1 AS Fld FROM Tbl A, Tbl B
WHERE (A.id=B.id+1) AND
(1=(SELECT MIN(id) FROM Tbl))



Страницы: 1 вся ветка

Текущий архив: 2002.10.10;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.015 c
1-31732
FireWorks
2002-10-01 12:38
2002.10.10
Размещение форм в dll


4-32066
kerrik
2002-08-22 22:40
2002.10.10
Как управл. другим прилож., посылая ему комбинации сокр. клавиш?


14-31964
DE@DM@N
2002-09-15 19:22
2002.10.10
Проблемы печати


14-31998
Profi
2002-09-17 08:16
2002.10.10
Посоветуйте хороший форум по администрированию W2k


1-31774
.JOHN.
2002-10-01 18:22
2002.10.10
Подскажите новичку