Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 30.07.2008, 17:38
Terio Terio вне форума
Новичок
 
Регистрация: 16.01.2008
Сообщения: 56
Репутация: 10
По умолчанию Транзакция, помогите пожалуйста!

Добрый день, уважаемые гуру!

Использую Midas по схеме:
Сервер:
MSSQL2000->ADOConnection->ADOQuery->DataSetProvider->
дальше клиент:
SocketConnection->ClientDataSet->DataSource->DBGrid.

Записи в БД вношу с помощью StoredProcedure по схеме:
Сервер:
MSSQL2000->ADOConnection->StoredProcedure->DataSetProvider->
дальше клиент:
SocketConnection->ClientDataSet->

Есть некий ClientDataSet1, из которого надо выбрать сразу несколько записей (в какой-то другой источник данных наверно) а затем провести транзакцию через StoredProcedure в БД, в другую таблицу.
Как сделать этот временный источник данных, не связанный физически с БД? Помогите пожалуйста, кто знает!
Ответить с цитированием
  #2  
Старый 30.07.2008, 19:04
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,907
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

А "некий ClientDataSet1" откуда выбирается? Из того же сервера?
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 30.07.2008, 19:44
Terio Terio вне форума
Новичок
 
Регистрация: 16.01.2008
Сообщения: 56
Репутация: 10
По умолчанию

Да, некий ClientDataSet1 с того же сервера.
Поясню, почему так муторно хочу сделать:
Есть таблицы:
"Клиенты":
CodClnt
NameClnt

"Заказы":
CodZac
NameZac

"Заказы-клиенты":
CodID
CodZac
CodClnt

В программе пользователь открывает форму заказа и начинает шпарить туда данные, открывает таблицу клиентов выбирает несколько записей (клиентов), затем тыкает "Сохранить заказ в БД". Заказ сохранятся в базу, ему присваивается свой уникальный код (CodZac), и в это же время в таблице "Заказы-клиенты" прописывается соответствия
CodZac-CodClnt, то есть тем клиентам, которых выбрал пользователь при создании заказа, ставится в соответствие код созданного заказа.
Так вот, ClientDataSet1 - это таблица клиентов, надо выбрать некоторые записи из него, затем сохранить заказ в БД и прописать соответствия CodZac-CodClnt. Вопрос: где хранить данные по выбранным записям в таблице "Клиенты" до проведения транзакции??

Последний раз редактировалось Terio, 30.07.2008 в 19:52.
Ответить с цитированием
  #4  
Старый 01.08.2008, 15:13
Terio Terio вне форума
Новичок
 
Регистрация: 16.01.2008
Сообщения: 56
Репутация: 10
По умолчанию

Все, разобрался самостоятельно. Оказывается все просто:
берем ClientDataSet будущей таблицы и просто редактируем на клиенте:

Код:
ClientDataSet2.Edit;
ClientDataSet2.Insert;
ClientDataSet2.FieldByName('Field1').Value:='Вася Пупкин';
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 10:44.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025