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

Вниз

CLientDataSet+SELECT 2 таблиц   Найти похожие ветки 

 
LinOS ©   (2003-10-02 11:18) [0]

Имеется БД. В ней таблицы A и B. SQLDataSet - Provider - ClientDataSet - DataSource- DBGrid.
таблицы

А B
-------- ----------
|id | |id |
|bid | |name |
|pid | |--------|
|amount|
--------
В ClientDataSet пишу:
ClientDataSet.CommandText="SELECT A.id, B.name, A.amount FROM A,B WHERE A.bid = B.id AND pid = 2";
ClientDataSet.Open

ВСе открывается показывает. Теперь хочу делать изменения.
Вставить name c id в DBGrid
И при ClientDataSet.ApplyUpdates(-1); Что бы записывалась B.id в A.bid.
Возможно такое.
Посоветуйте, как грамотнее осуществить.


 
Nikolay M. ©   (2003-10-02 11:34) [1]

Provider.ResolveToDataSet := True & Provider.BeforeUpdateRecord?
Попутно вопрос - как получается ID?


 
LinOS ©   (2003-10-02 11:45) [2]

С id все нормально - autoincrement.


 
Nikolay M. ©   (2003-10-02 11:51) [3]


> С id все нормально - autoincrement.

Это как раз НЕнормально (если автоинкремент происходит на уровне БД).
Каким образом ты будешь узнавать его значение из главной таблицы, чтобы потом вставлять его в подчиненную?
http://rsdn.ru/article/db/midas_migration.xml#XSLTSECTION124143120120


 
LinOS ©   (2003-10-02 11:57) [4]

В подчиненную таблицу ничего не вставляю - только беру информацию для вставки (id) и отображения (name).
Спасибо. А небольшой привер можно для полного понимания. А именно как сформировать SQL в Provider.BeforeUpdateRecord если одна строка добавлена, одна изменена, другая удалена?


 
LinOS ©   (2003-10-02 12:16) [5]

Все Николай, спасибо огромное.
Главное навести на правильный путь.



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

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

Наверх




Память: 0.47 MB
Время: 0.022 c
1-74294
Delphi5.01
2003-10-11 23:33
2003.10.23
WordDocument1.Range.Find.Execute


14-74386
ORMADA
2003-10-01 12:35
2003.10.23
DCU


1-74251
Александр М.
2003-10-12 18:50
2003.10.23
TreeView


6-74337
Maxim
2003-08-29 20:30
2003.10.23
Работа с почтовым клиентом


7-74487
MyNik
2003-07-24 09:23
2003.10.23
Воспроизведение wav в телефонную линию через модем