Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 29.05.2015
Сообщений: 6

Поиск отсутствующего значения ID

01.06.2017, 12:10. Показов 2289. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здраствуйте) Есть таблица тест с полями id (integer), name(text) где id первичный ключ. Нужно написать ф-я для вставки строк в таблицу, в которой будет реализовано условие поиска "пропущенных" id. Реализовала вот так:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
CREATE OR REPLACE FUNCTION public.ins_test(
    name1 text)
  RETURNS void AS
$BODY$
DECLARE
ddd INTEGER;
BEGIN
SELECT (test.id+1) FROM test
WHERE (SELECT 1 FROM test AS st 
    WHERE st.id = (test.id + 1)) IS NULL
ORDER BY test.id LIMIT 1 INTO ddd;
INSERT INTO public."test"("id","name")
    VALUES (ddd, name1);
END
$BODY$
  LANGUAGE plpgsql VOLATILE
Допустим в таблицу есть значения:

id=3, name='test1';
id=5, name='test2';

При вызове ф-и будут вставлены строки с id 4,6,7,8,10 и т.д., но id 1,2 добавлены не будут. Как можно исправить ф-ю что бы вставлялись первые id?

Добавлено через 4 часа 57 минут
Тема закрыта, помогли на другом форуме. Кому интересно:

Oracle 11 SQL
1
2
3
4
5
INSERT INTO test (id, name) SELECT id, name1 FROM (
  SELECT id FROM generate_series(1,(SELECT MAX(id)+1 FROM test)) AS t(id)
  except
  SELECT id FROM test
) t;
Этот запрос вставит все пропущенные значения. Хотите вставлять по одной строке — добавьте order by id limit 1
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.06.2017, 12:10
Ответы с готовыми решениями:

Поиск отсутствующего значения в массиве
Есть один массив (база) $array1 Array ( => Array ( => 5425RD => 5425RD Катушка DIAMOND ...

Поиск отсутствующего целого числа
Массив A содержит все целые числа от 0 до n за исключением одного. Отсутствующее число можно легко определить за время О(n), располагая...

Поиск по вектору наименьшего отсутствующего элемента
В общем, есть вектор, в нем хранятся значения типа <unsigned int>. Как за наименьшее количество проходов по вектору найти наименьший...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.06.2017, 12:10
Помогаю со студенческими работами здесь

Поиск отрицательного значения, а так же деление, поиск максимального значения и запись в таблицу
Помогите пожалуйста дорешать две задачки: Вобщем первая задачка заключается в том, что надо сформировать массив из N чисел, их...

Удаление отсутствующего оборудования
На довольно старом нетбуке то ли из-за кривых драйверов 3G модема, то ли еще из-за чего оказались занятыми COM-порты вплоть до СОМ16. Так...

Алгоритм поиска отсутствующего элемента
Подскажите алгоритм поиска отсутствующего элемента. Допустим у нас есть 100 элементов Мы опрашиваем их с разной частотой. Как...

Поиск значения из одной книги в другой и вставка этого значения
Привет форумчане. Требуется ваша помощь. Мне из книги "Разобрано" нужно найти в "Справочнике" сначала лист с брендом, а затем в...

Поиск значения в двухмерном массиве с выводом значения соседнего индекса
Надеюсь поймут с первого раза. Имеется массив который мы получаем к примеру из файла или парсером, неважно. Назовём его $array_one Он...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru