Поиск:

Ответ в темуСоздание новой темы Создание опроса
> проверка существования поля в таблицах 
V
    Опции темы
JS2
Дата 18.6.2010, 11:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 55
Регистрация: 25.3.2009

Репутация: нет
Всего: нет



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

Код

procedure chk_fld(const fld_name: string; tbl_ID: Integer;
 out fld: TField);
const
 TBL_NAME_GROUP = 'group_%d';
var
 cmp_tbl: TDBISAMTable;
 tbl_name: string;
begin
 tbl_name := Format(TBL_NAME_GROUP, [tbl_ID]);
 cmp_tbl := TDBISAMTable.Create(nil);
 try
   cmp_tbl.DatabaseName := DB_NAME;
    cmp_tbl.SessionName := SESSION_NAME;
      cmp_tbl.TableName := tbl_name;
   cmp_tbl.Open;
   fld := cmp_tbl.FindField(fld_name);
 finally
   cmp_tbl.Free;
 end;
end;

procedure Tfrm_Test.Button1Click(Sender: TObject);
var
 All, I: Integer;
begin
 for I := 0 to All - 1 do
 begin
   { ... }
   if tbl_ID_exists(tbl_ID) then
   begin
     chk_fld(fld_name, tbl_ID, fld);
     if fld <> nil then
       { ... }
     else
       { ... }
   end;
 end;
end;

PM MAIL   Вверх
Rennigth
Дата 18.6.2010, 11:43 (ссылка) |  (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1708
Регистрация: 21.6.2004
Где: Moscow

Репутация: нет
Всего: 76



JS2
1. Зачем открывать всю таблицу когда можно сделать обыкновенный (select top 0).
2. Вроде это можно спросить и у самой базы? По крайней мере в mssql-server-e что-то такое было.

п.с. Не знаю что у тебя за база и что это (TDBISAMTable) за зверь такой.


--------------------
(* Honesta mors turpi vita potior *)
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0527 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.