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

Вниз

работа с таблицей бд из класса   Найти похожие ветки 

 
_qwerty_   (2011-11-28 23:08) [0]

есть таблица, которая содержит разнородные записи и есть класс, который включает методы навигации по записям в этой таблице. как правильнее всего организовать доступ к таблице.

1. через конструктор передавать TDBISAMDatabase и создавать экземляр объекта TDBISAMTable и работать с ним.


TNavigator = class
private
 FTableOfItems: TDBISAMTable;
public
 constructor Create(Database: TDBISAMDatabase); // <- FTableOfItems := TDBISAMTable.Create; ... FRableOfItems.Open
 destructor Destroy; override;
 procedure GoToFirst(Where: Integer);
 procedure GoToLast(Where: Integer);
 procedure GoToNext(Where: Integer);
 procedure GoToPrevious(Where: Integer);  
end;


2. через конструктор передавать уже созданный экземляр объекта TDBISAMTable и работать с ним.


TNavigator = class
private
 FTableOfItems: TDBISAMTable;
public
 constructor Create(TableOfItems: TDBISAMTable); // <- FTableOfItems := TableOfItems
 destructor Destroy; override;
 procedure GoToFirst(Where: Integer);
 procedure GoToLast(Where: Integer);
 procedure GoToNext(Where: Integer);
 procedure GoToPrevious(Where: Integer);  
end;


3. по-другому.


 
Loginov Dmitry ©   (2011-11-28 23:41) [1]


> как правильнее всего организовать доступ к таблице


С точки зрения пользователя твоей программы - без разницы, главное, чтобы работало.

С точки зрения программиста - так же без разницы, главное, чтобы было максимально понятно, логично, с минимальным объемом кода.

Если строить аналогию с DB-компонентами типа TDataSet, то более логичным выглядит первый вариант. Но тебе должно быть виднее.


 
DiamondShark ©   (2011-11-29 02:30) [2]


> 3. по-другому.

Выкинуть этот класс в корзину.
Никому нафиг не нужен класс системы ниппель: вход есть, а выхода нет. Даже побочного эффекта от изменения сакрального внутреннего состояния нет.

Ты из постановки задачи выкинул самое интересное -- ответ на основной вопрос системотехники.
А в представленном виде ответ может быть только один: "без разницы"(Ц).



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

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

Наверх




Память: 0.47 MB
Время: 0.01 c
15-1319910376
KilkennyCat
2011-10-29 21:46
2012.03.11
налог на носители


15-1321561802
Юрий
2011-11-18 00:30
2012.03.11
С днем рождения ! 18 ноября 2011 пятница


2-1322567877
Gu
2011-11-29 15:57
2012.03.11
длина пароля из политик


2-1322561090
Evgen88
2011-11-29 14:04
2012.03.11
помогите разобраться с TEdit


2-1322552557
YURY
2011-11-29 11:42
2012.03.11
Потоки