Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.02.28;
Скачать: [xml.tar.bz2];




Вниз

SQL+ 


VIB   (2002-02-01 17:27) [0]

Есть некая таблица Customer, в которой существует некоторое целочисленное поле ID, служащее первичным ключем. В процессе работы в таблицу добавляются и удаляются записи. После удаления возникают так называемые дырки (к примеру 1,2,4,5,7,8). Необходимо одним запросом найти любую дырку



}{unter   (2002-02-01 18:17) [1]

Да вопрос интересный ! Сижу репу чешу. По-моему так сходу не ответишь. Пишу проверяю. Может быть раньше кто нарисует - интересно посмотреть !



AlexR_R   (2002-02-01 19:43) [2]

Может есть что-то лучше, первое что пришло в голову


select t1.* from test t1
where
not exists(select id from test t2 where t2.ID > t1.ID and t2.id <= t1.ID + 1)

Получишь все номера к которым прибавив единицу получишь пустой ID
Если добавить order by t1.ID, то первая запись плюс один
будет минимальным ID



VIB   (2002-02-02 13:06) [3]

Спасибо AlexR_R за ответ. Но он работает неправильно.
Если есть последовательность 1,2,4,5,7,8 то запрос выдает
результат 2,5,8



VIB   (2002-02-02 13:55) [4]

Если кому-то интересно то я раздолбал проблему.Запрос
select a.id+1 nom from cust.db a
where not exists(select b.id from cust.db b where a.id+1=b.id )




Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.02.28;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.022 c
6-90632           vsu                   2001-12-12 21:52  2002.02.28  
e-mail из консольного приложения


14-90662          Polevi                2002-01-15 17:46  2002.02.28  
Civilization 3


3-90461           Rad                   2002-01-31 19:15  2002.02.28  
Как выяснить размерность поля Numeric?


4-90704           Woron                 2001-12-24 19:18  2002.02.28  
Диалог OpenFolder


1-90572           stx                   2002-02-12 09:31  2002.02.28  
есть ли в DELPHI аналог Collections (BP7)