Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.07.18;
Скачать: CL | DM;

Вниз

ADO - Access - Как получить значение сгенеренного ID - counter   Найти похожие ветки 

 
ike   (2005-06-02 11:22) [0]

Есть база Access. Вставляю новую запись в таблицу (TADOQuery), в которой первичный ключ с типом Counter. После чего мне надо вставить ещё записи в таблицы, где этот ключ тоже входит в состав первичного ключа. Нужно получить его значение и втавить соответствующие записи в эти таблицы. Сделать нужно в одной транзакции. В SQL сереверах это делается просто через хранимую процедуру, а как это можно в Access организовать?


 
msguns ©   (2005-06-02 11:36) [1]

Для акцесса (однопользовалка) можно использовать запрос
SELECT MAX(ID)+1 FROM TABLE, а затем
..
Open;

INSERT INTO TABLE ID,... VALUES (:ID,...)

ADOCommand1.ParamByName("ID").Value := ADOQueryGetID.Fields[0].AsInteger;


 
ike   (2005-06-02 12:11) [2]

Если я правильно понял, то мне вначале нужно получить значение будующего ID (max(id)+1). А каждую операцию INSERT с этим ID я должен в отдельных Query/Command etc выполнять?


 
msguns ©   (2005-06-02 12:24) [3]

выборка ID производится один раз для каждой вставляющей в Мастер-таблицу операции. Это же значение используется при вставках всех записей всех Detail-таблиц.
Однако, если использовать связь Master-Detail (DetailQuery.DataSource := MasterDataSource), то при вставках в деталы заполнение мастер-ключа будет производится автоматически.


 
ЮЮ ©   (2005-06-02 12:40) [4]

>msguns ©   (02.06.05 11:36) [1]

При таком подходе проще избавиться от Counter-а, заменив на Integer.

Кстати не обязательно  MAX(ID)+1 должен дать правильное значение. А что если запись была добавлена, а потом удалена. Это только Access XP при очиске таблицы и насильственной вставки записи с меньшим Id сбрасывает счетчик (такая метода дана даже в Неlp-e, уж-ж-ж-ас), а, например, в Access 2000, счетчик продолжает в этом случае благополучно нарастать


 
Sergey13 ©   (2005-06-02 12:45) [5]

2ike   (02.06.05 11:22)
>В SQL сереверах это делается просто
И что людей заставляет ими не пользоваться? А потом еще пытаться сделать что либо "в одной транзакции".
8-)


 
Anatoly Podgoretsky ©   (2005-06-02 15:00) [6]

@@IDENTITY



Страницы: 1 вся ветка

Текущий архив: 2005.07.18;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.072 c
5-1090160484
Maxim
2004-07-18 18:21
2005.07.18
Иконка, Сообщения


1-1119785543
serg128
2005-06-26 15:32
2005.07.18
Как вычитывать файл построчно используя TFileStream?


14-1119420925
Игорь Шевченко
2005-06-22 10:15
2005.07.18
11 вещей, которым вас забыли научить в школе.


14-1119390702
Zelius
2005-06-22 01:51
2005.07.18
В чем провинился кернел?


1-1120384016
aapp
2005-07-03 13:46
2005.07.18
Использование *.h