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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 02.03.2016, 23:06
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Суть идеи в том, что в этом режиме данные не пишутся сразу в базу, а хранятся в памяти этим и можно воспользоваться. Вот скажем у меня есть вот такая структура и запрос к ней:
Код:
SELECT Building.Building, Floor.Floor, Room.Room, Socket.Socket
FROM ((Building INNER JOIN Floor ON Building.BuildingId = Floor.BuildingID) INNER JOIN Room ON Floor.FloorId = Room.FloorID) INNER JOIN Socket ON Room.RoomId = Socket.RoomId;
Такой запрос нельзя редактировать напрямую, поэтому мы выставляем для него:
Код:
ADOQuery1.LockType := ltBatchOptimistic;
и самостоятельно обрабатываем сохранение данных:
Код:
procedure TForm9.ADOQuery1AfterPost(DataSet: TDataSet);
Var DS: TAdoDataSet;
    ID: Integer;
begin
 DS := TAdoDataSet.Create(nil);
 DS.Connection := AdoConnection1;

 DS.CommandText := 'Building';
 DS.CommandType := cmdTable;
 DS.Open;
 DS.AppendRecord([nil, DataSet['Building']]);
 ID := DS['BuildingID'];
 DS.Close;

 DS.CommandText := 'Floor';
 DS.CommandType := cmdTable;
 DS.Open;
 DS.AppendRecord([nil, ID, DataSet['Floor']]);
 ID := DS['FloorID'];
 DS.Close;

 DS.CommandText := 'Room';
 DS.CommandType := cmdTable;
 DS.Open;
 DS.AppendRecord([nil, ID, DataSet['Room']]);
 ID := DS['RoomID'];
 DS.Close;

 DS.CommandText := 'Socket';
 DS.CommandType := cmdTable;
 DS.Open;
 DS.AppendRecord([nil, ID, DataSet['Socket']]);
 DS.Close;

 DS.Free;
end;
Изображения
Тип файла: png Схема.png (4.0 Кбайт, 6 просмотров)
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
Uniq! (09.03.2016)
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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