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

Вниз

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 )




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

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

Наверх




Память: 0.47 MB
Время: 0.005 c
4-90711
Diablo_al
2001-12-29 18:40
2002.02.28
Help!!! Можно ли передавать звук с микрофона


1-90537
anod
2002-02-09 10:16
2002.02.28
Печать QReport


7-90678
ISA
2001-11-25 12:40
2002.02.28
Работа с COM-портом


3-90524
RAVEN
2002-02-04 13:08
2002.02.28
Отмена удаления записи


3-90529
dimich
2002-02-05 18:32
2002.02.28
Помогите с ADO