Главная страница
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.011 c
1-31757
Дмитрий К.К.
2002-09-30 23:43
2002.10.10
Creation Order


14-31985
MaximatorVeter
2002-09-16 14:58
2002.10.10
Какая последняя версия у след. пакетов:


8-31904
Burjuy
2002-06-09 04:49
2002.10.10
Как определить можно ли проиграть звук


1-31771
Valeris
2002-10-01 18:39
2002.10.10
Програмный пинг


3-31631
Sergant
2002-09-18 16:23
2002.10.10
Delphi+Rs-Bank