Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 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 )




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

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

Наверх




Память: 0.44 MB
Время: 0.004 c
1-90589
Alexandr
2002-02-12 13:27
2002.02.28
Фреймы


3-90452
ТеньЛуны
2002-02-01 14:02
2002.02.28
CalcFields


4-90714
Profi .
2001-12-30 16:27
2002.02.28
SHELLEXECUTE !!!! HELP !!!


14-90652
SV
2002-01-13 14:48
2002.02.28
Алгоритм и ещё кое-что.


3-90510
HDD
2002-02-04 05:35
2002.02.28
Допоможите гарны хлопчики и дивченки





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский