Форум: "Базы";
Поиск по всему сайту: 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.012 c
4-90709           Run                   2001-12-23 22:15  2002.02.28  
winexec


4-90701           Olgerd                2001-12-27 20:24  2002.02.28  
Рвём коннект


1-90624           ruslan_as             2002-02-13 11:16  2002.02.28  
Поставить все DBEdit в Enabled:=False;


3-90522           ЕвгенийА              2002-02-02 00:57  2002.02.28  
Ошибочка при открытии базы...


4-90695           mikrom                2001-12-28 15:07  2002.02.28  
Выгрузка DLL