1 / 1 / 0
Регистрация: 10.10.2012
Сообщений: 10

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

10.10.2012, 13:25. Показов 2253. Ответов 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
Сообщений: 463
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru