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

Delphi Sources



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

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

Суть идеи в том, что в этом режиме данные не пишутся сразу в базу, а хранятся в памяти этим и можно воспользоваться. Вот скажем у меня есть вот такая структура и запрос к ней:
Код:
1
2
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;
Такой запрос нельзя редактировать напрямую, поэтому мы выставляем для него:
Код:
1
ADOQuery1.LockType := ltBatchOptimistic;
и самостоятельно обрабатываем сохранение данных:
Код:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
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)
 


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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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