Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
1 / 1 / 0
Регистрация: 10.10.2012
Сообщений: 10

Автоинкремент ключевого индекса

10.10.2012, 13:25. Показов 2238. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
БД состоит из одной таблицы, для добавления новых записей использую следующий участок кода:

Delphi
1
2
3
4
5
6
7
8
9
adoquery1.append;
adoquery1.FieldByName('number').AsString:=number;
adoquery1.FieldByName('type').AsString:=tip;
adoquery1.FieldByName('title').AsString:=title;
adoquery1.FieldByName('creator').AsString:=creator;
adoquery1.FieldByName('ddmmyy').AsString:=ddmmyy;
adoquery1.FieldByName('shop').AsString:=shop;
adoquery1.FieldByName('place').AsString:=place;
adoquery1.FieldByName('comment').AsString:=comment;
За сохранение записи в таблице отвечает
Delphi
1
adoquery1.updatebatch(arall);
Тип ключевого поля ID - счетчик (соответственно, работает автоинкремент):


При работе программы, после тестового добавления и сохранения записи наблюдаю следующий результат:


Так понял, что каким-то образом даже после перезапуска программы значение счетчика накапливалось и сохранялось, увеличиваясь на 1 с каждой новой записью. И после удаления записи счетчик "накапливается", отладкой увидеть проблемную область не вышло. Как-то "не кошерно" выходит, в общем
В чем может быть причина такого поведения?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.10.2012, 13:25
Ответы с готовыми решениями:

Задание индекса у ключевого поля таблицы Access
При добавлении ключевого поля в таблицу необходимо задать ему индекс(ADD CONSTRAINT), а то автоматически создаваемый не знаю как узнать...

В данном линейном целочисленном массиве каждый элемент с четным индексом увеличить на значение индекса, с нечетным — уменьшить на значение индекса
В данном линейном целочисленном массиве каждый элемент с четным индексом увеличить на значение индекса, с нечетным — уменьшить на значение...

Id автоинкремент
доброе утро. у меня такой вопрос. есть таблица в ней id является автоинкрементом . если я создам запрос, INSERT INTO...

5
132 / 129 / 31
Регистрация: 12.12.2011
Сообщений: 462
10.10.2012, 14:58
Проблемы здесь нет. Все именно так и должно быть. Счетчик будет расти пока не упрется в предел, но я вас уверяю, что это будет очень и очень не скоро, даже если вы будете каждый день работать с базой. Лет 10 можете не париться.
1
1 / 1 / 0
Регистрация: 10.10.2012
Сообщений: 10
10.10.2012, 16:30  [ТС]
А все-таки, можно ли его заставить считать не как ему вздумается, а от последнего значения в таблице? Или смысла особо и нет заниматься этим?
0
 Аватар для HyperZen
498 / 251 / 56
Регистрация: 16.06.2011
Сообщений: 904
10.10.2012, 18:38
Это поле и было задумано как уникальное, если хотите "плясать" от последней записи в БД, то заведите свое собственное поле, в котором добавляйте к каждой новой записи +1 к количеству существующих.
0
Кратк. - сест. тал.
 Аватар для Vit@L
87 / 51 / 4
Регистрация: 13.03.2008
Сообщений: 543
13.10.2012, 22:51
Но велика вероятность что значение повторится, если не делать проверку. Если оно не долно быть уникальным, то можно сделать как посоветовал HyperZen
0
 Аватар для Alex_pac
1302 / 708 / 107
Регистрация: 25.05.2011
Сообщений: 2,158
Записей в блоге: 51
14.10.2012, 11:59
в базе аккесс счетчику можно поставить "случайные" значения не а последовательные тогда предел не ограничен практически ничем
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.10.2012, 11:59
Помогаю со студенческими работами здесь

Автоинкремент
Есть бд InterBase, в ней примитивная таблица. Для поля id созданы генератор и триггер. При работе с таблицей через IBExpert заполняю все...

АвтоИнкремент
а как можно сбрасывать счетчик в 1, когда таблица уже пустая, а то оно помнит последнее значение, как-то не очень смотриться таблица на...

автоинкремент
ms sql 2005 через Server Management Studio просматриваю табличку, первая колока автоинкремент, значания д.б. 1, 2, 3 ...n. Если 2 сточку...

Автоинкремент в FB
ДОброго времени суток товарищи, проблема при создании таблицы в Фаирбёрде, одно из полей таблицы автоинкремент... id_cl, integer, not...

Автоинкремент
Здравствуйте! Для одного из атрибутов отношения установил свойство автоинкремента (Identity) с начальным значением 1 и шагом 1. Но при...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru