|
Вопрос # 1 303/ вопрос открыт / |
|
Здравствуйте, уважаемые эксперты!
Каким образом можно изменить текущее значение AUTO_INCREMENT в таблице Paradox? В Database Desktop соответствующей настройки, по видимому, нет.
 |
Вопрос задал: Sunshine (статус: Посетитель)
Вопрос отправлен: 30 января 2008, 21:00
Состояние вопроса: открыт, ответов: 1.
|
Ответ #1. Отвечает эксперт: Вадим К
Здравствуйте, Sunshine!
На то оно и автоинкрементное поле, что оно само изменяется. Так задумано. Это наиболее простой способ обеспечить уникальность значений. Возможно вас смущает то, что удалив все записи с таблицы, это поле начинается не с 1 (или 0), а продолжает свой счёт. Это тоже нормально. Позже, когда с базами начнёте плотнее работать назначение этого, казалось бы дивного свойства, станет понятным.
Хотя есть один полузаконный способ сменить автоинкрементое поле - сделать тип поля числовым. потом, поправивь нужны записи, назад в автоинкремент.
НО!
-не все базы ведуться на это.
-если будет нарушена уникальность - не даст ни одна нормальная база так сделать.
 |
Ответ отправил: Вадим К (статус: Академик)
Время отправки: 31 января 2008, 00:39
Оценка за ответ: 4
Комментарий к оценке: Я отлично знаю, что так и задумано, что это основной принцип БД. Но, к примеру, в MySQL такую операцию очень легко провернуть. То, что при очистке значение сохраняется - тоже логично, я с этим не спорю. Но если, к примеру, тестировать что-либо, то потом вернуть таблицу к исходному состоянию невозможно - придётся просто заново её создавать...
По поводу "сделать тип поля числовым. потом, поправивь нужны записи, назад в автоинкремент" - получится изменить только ID записей, хотя цель - изменить значение автоинкремента на 1, как будто таблица только что была создана.
Спасибо за ответ.
|
Мини-форум вопроса
Всего сообщений: 6; последнее сообщение — 3 февраля 2008, 09:56; участников в обсуждении: 2.
|
Вадим К (статус: Академик), 31 января 2008, 23:02 [#1]:
Я так понял, ответ не до конца удоволетворил вас.
>>Но если, к примеру, тестировать что-либо, то потом вернуть таблицу к исходному состоянию невозможно - придётся просто заново её создавать...
Эта проблема решается по другому. Просто надо сделать копию базы для тестов и перед запуском восстанавливать с нужной копии. Для некоторых баз (Access, SQLite) можно обойтись банальным копированием. А для других (FireBird) - есть специальные методы.
В новой Visual Studio эту проблему решили по другому. Они хранят не базу, а сиквел запрос для создания и наполнения её. Перед запуском просто запускается скрипт. Сиквелсервер обрабатывает их очень быстро по сравнению с ручным или програмным наполнением.
Этот способ имеет ещё одно несомненное приимущество - эти файлы легко хранить в CVS (SVN), и визуально сравнивать. Также легко менять типы баз.
Галочка "подтверждения прочтения" - вселенское зло.
|
|
Sunshine (статус: Посетитель), 1 февраля 2008, 08:46 [#2]:
Про копирование знаю - так, в общем-то, и делал...
Про создание таблицы запросом - тоже хорошая идея. Этот вариант даже лучше.
Кстати, в MySQL такое изменение делается запросом вроде (точно не помню) "ALTER TABLE ... AUTO_INCREMENT = 1". В Paradox такой не пройдёт?
|
|
Вадим К (статус: Академик), 1 февраля 2008, 15:54 [#3]:
PARADOX => BDE? Бегите от него.
Галочка "подтверждения прочтения" - вселенское зло.
|
|
Sunshine (статус: Посетитель), 1 февраля 2008, 17:17 [#4]:
Да это понятно 
Ну а в других БД как? Такая же проблема с этим?
|
|
Вадим К (статус: Академик), 2 февраля 2008, 23:10 [#5]:
с Access таких проблем практически нет. SQLite - там вообще без проблем. С небольшими проблемами начинает работать FireBird(InterBase) - они начинаются, когда надо что бы на одной машине два сервера работали (да, есть и такие извращенцы). МОжно конечно разнести их на разные порты, но многие програмисты даже не думают о том, что их творение может работать на других портах.
Галочка "подтверждения прочтения" - вселенское зло.
|
|
Sunshine (статус: Посетитель), 3 февраля 2008, 09:56 [#6]:
Понятно. Большое спасибо за информацию!
|
Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.
|