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

Вниз

проверка существования поля в таблицах   Найти похожие ветки 

 
LDV   (2010-06-18 12:08) [0]

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


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;


 
Ega23 ©   (2010-06-18 12:21) [1]

Select 1 from sysobjects where id=object_id(N"[ttt]") and OBJECTPROPERTY(id, N"IsProcedure")=1


 
Ega23 ©   (2010-06-18 12:25) [2]

А, стоп. Тебе поле.
Тогда так:
select COLUMNPROPERTY(OBJECT_ID(N"[Имя_таблицы]"), "Имя_столбца", "precision")


 
LDV   (2010-06-18 12:28) [3]

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



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

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

Наверх




Память: 0.47 MB
Время: 0.011 c
15-1276810212
Юрий
2010-06-18 01:30
2010.09.12
С днем рождения ! 18 июня 2010 пятница


2-1276721389
GanibalLector
2010-06-17 00:49
2010.09.12
TClientSocket в DLL


2-1276534233
akosh12345
2010-06-14 20:50
2010.09.12
Вывод кнопок динамически


11-1196527644
Byka (345-824-826)
2007-12-01 19:47
2010.09.12
помогите с Lazarus?


2-1276593784
Pavel
2010-06-15 13:23
2010.09.12
Работа с dbf-таблицами