Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Как в Delphi узнать значение поля типа AutoInc в таблице ти

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Vladgul



Зарегистрирован: 29.06.2004
Сообщения: 12

СообщениеДобавлено: Ср Июл 28 2004 09:03    Заголовок сообщения: Как в Delphi узнать значение поля типа AutoInc в таблице ти Ответить с цитатой

Как в Delphi узнать значение поля типа AutoInc в таблице типа Paradox до сохранения новой записи.
Задача такая: при создании новой записи, прежде чем сохранять данные, мне нужно выполнить некоторые действия, причем я обязательно должен знать значение поля ID типа AutoInc ДО СОХРАНЕНИЯ данных в таблице.

Можно ли каким-либо образом узнать будущее значение этого поля?

P.S.
Ведь где-то значение это хранится, потому что даже если в существующей базе удалить все записи, то поля типа AutoInc все равно будут продолжать с последнего выданного номера.

Если нет, то какие есть идеи как узнать значение поля?
Rolling Eyes Можно наверное, конечно и сохранить, узнать значение поля, выполнить действия, и если они не успешные, то удалить эту запись. Но как-то это "коряво".
Помогите пожалуйста, кто может Smile
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
_Михаил_
Гость





СообщениеДобавлено: Ср Июл 28 2004 15:19    Заголовок сообщения: Re: Как в Delphi узнать значение поля типа AutoInc в таблице ти Ответить с цитатой

Может я что-то не так понял, но зная значение этого поля для последней записи и зная шаг приращения можно перед вставкой новой записи определить значение поля. Так?
Вернуться к началу
wildwind



Зарегистрирован: 03.02.2004
Сообщения: 268
Откуда: Москва

СообщениеДобавлено: Ср Июл 28 2004 19:08    Заголовок сообщения: Ответить с цитатой

Никак.

Нужно использовать транзакции. То есть:
Начать транзакцию, "сохранить, узнать значение поля, выполнить действия, и если они не успешные, то" откатить транзакцию.
А если все OK то зафиксировать транзакцию.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Vladgul



Зарегистрирован: 29.06.2004
Сообщения: 12

СообщениеДобавлено: Чт Июл 29 2004 13:35    Заголовок сообщения: А если с двух компов такие-же действия производить, то Ответить с цитатой

начав транзакцию на одном сохранив запись и узнав номер ID
на другом при страте транзакции будет выдан тот же номер ID, если транзакция еще открыта на первом?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
wildwind



Зарегистрирован: 03.02.2004
Сообщения: 268
Откуда: Москва

СообщениеДобавлено: Пн Авг 02 2004 16:25    Заголовок сообщения: Ответить с цитатой

На чем "на одном", "на другом"?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Vladgul



Зарегистрирован: 29.06.2004
Сообщения: 12

СообщениеДобавлено: Пн Авг 02 2004 20:45    Заголовок сообщения: На одном и на другом КОМПЬЮТЕРАХ Ответить с цитатой

При многопользовательском доступе к БД с разных компов.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
wildwind_
Гость





СообщениеДобавлено: Пн Авг 02 2004 21:59    Заголовок сообщения: Ответить с цитатой

Нет. А ты еще не проверил? Smile
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...