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

Вниз

Как организовать мастер детайл с компонентами ADO   Найти похожие ветки 

 
Term   (2004-09-27 15:23) [0]

Как правильно использовать TADOQuery
не матюкайте
дайте пример для таблиц такой структуры

Master
id bigint identity
name varchar 30

Detail
id bigint identity
id_master bigint
det_name


 
msguns   (2004-09-27 15:30) [1]

Мастер читаешь как обычно, а вот детал..
Стандартный способ указать в его DataSource ссылку на Мастер и связать их через мастер-ключ(в данном случае id). При таком подходе не надо сушить башку для синхронизированного обновление курсора детала. Однако с обновление записей детала (да и мастера) надо быть осторожным, чтоб не порушить эту самую "связь"


 
Term   (2004-09-27 15:36) [2]

да насчёт датасорсурса я в курсе
я вот что имел ввиду
скажем в ADOQuery1  я поместил такой запрос на вставку

insert into master
(name)
VALUES
(:name)


какой запрос надо поместить во второй зависимый компонент чтобы получить значение Master.Id которое выдаст сервер


 
Johnmen ©   (2004-09-27 15:39) [3]

>Term   (27.09.04 15:36) [2]

http://delphimaster.net/view/3-1095759267/


 
msguns   (2004-09-27 15:49) [4]

Если связь через св-во DataSource, то ничего никуда помещать не надо - оно типа само "разберется", перестроив запрос к деталу автоматически. Но для "осознанного" апдэйта данных ЛИЧНО Я делаю запрос на определение нового астер ID (и не Мастер тоже) отдельно, после чего уже рисую запросы на вставку. При таком подходе я уверен, что никаких эксцессов не возникнет НЕЗАВИСИМО ОТ КОМПОНЕНТОВ, которые я использую для доступа к БД


 
Term   (2004-09-27 16:10) [5]

т.е. так если что поправьте

INSERT INTO Master(NAME) VALUES("Фирма")
SELECT @@IDENTITY AS id


 
Term   (2004-09-27 16:15) [6]

т.е.

INSERT INTO Master(NAME) VALUES("Фирма");
SELECT @@IDENTITY AS id;
INSERT INTO Detail(id_master, DET_NAME) VALUES(id,"Detal");


 
sniknik ©   (2004-09-27 16:21) [7]

тогда уж
INSERT INTO Master (NAME) VALUES ("Фирма")
INSERT INTO Detail (id_master, DET_NAME) VALUES (@@IDENTITY, "Detal")
и все


 
Term   (2004-09-27 16:24) [8]


> INSERT INTO Master (NAME) VALUES ("Фирма")
> INSERT INTO Detail (id_master, DET_NAME) VALUES (@@IDENTITY,
> "Detal")

а если привязанно будет не одна таблица а скажем 3 или 4 то
@@IDENTITY бутем для третьей таблицы от мастеровской таблицы или уже от предыдушего запроса в детальную


 
sniknik ©   (2004-09-27 16:59) [9]

сам смотри что тебе больше подходит
в BOL загляни, IDENT_CURRENT пойдет для > 1, 3 - 4, либо сохрани значение в своей переменной и его используй.



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

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

Наверх




Память: 0.48 MB
Время: 0.023 c
9-1087896999
Grez
2004-06-22 13:36
2004.10.24
Как написать Стратегию???


4-1095768486
Aleksandr.
2004-09-21 16:08
2004.10.24
Будет ли форма получать и обрабатывать сообщения при ожидании?


14-1096818243
Нович[Ок]
2004-10-03 19:44
2004.10.24
Работа


10-1050575071
Vofka
2003-04-17 14:24
2004.10.24
Помогите начинающему с CORBA


3-1096033930
borissv
2004-09-24 17:52
2004.10.24
Перехват ошибки ???????????