Форум: "Базы";
Текущий архив: 2002.04.29;
Скачать: [xml.tar.bz2];
ВнизИндексы в отдельном каталоге Найти похожие ветки
← →
Viktor Erko (2002-04-08 08:49) [0]Понимаю, что это извращение но не я писал оригинальную версию ПО.
Мне нужно только викачивать информацию.
...program\dbf\*.dbf
...........\cdx\*.cdx
Посоветуйте как научить Delphi искать индексы в другом каталоге и имитировать виполнение команды REINDEX
C Уважением
Виктор
← →
Сергей Иванов (2002-04-08 09:25) [1]//Не претендую на элегантость решения, но работает уже более года ;)
//Открывать попробуй так:
const CDXPath = "f:\Bumi1\IDX";
procedure TParusServer.OpenTbl(Tbl: TTable);
var FullName :string;
cdx :TStringList;
begin
if not Tbl.Active then Tbl.Active := true;
FullName:=UpperCase(fDbiFormFullName(Tbl));
if Pos("DBF", FullName) > 0 then
Insert("IDX", FullName, Pos("DBF", FullName));
Delete(FullName, Pos("DBF", FullName), 3);
if Pos("DBF", FullName) > 0 then
Insert("CDX", FullName, Pos("DBF", FullName));
Delete(FullName, Pos("DBF", FullName), 3);
cdx := TStringList.Create;
cdx.Add(FullName);
if Tbl.Active then Tbl.Active := false;
Tbl.IndexFiles := cdx;
if not Tbl.Active then Tbl.Active := true;
end;
function fDbiFormFullName(Tbl: TTable): string;
var Props: CurProps;
begin
Check(DbiGetCursorProps(Tbl.Handle,Props));
SetLength(Result, DBIMAXPATHLEN);
Check(DbiFormFullName(Tbl.DBHandle, PChar(Tbl.TableName),
Props.szTableType, PChar(Result)));
end;
//закрываем
procedure CloseTbl(Tbl: TTable);
begin
if not Tbl.Active then exit;
Tbl.Active := false;
Tbl.IndexFiles.Free;
end;
//не Парус ли у тебя случАем?
← →
Сергей Иванов (2002-04-08 09:28) [2]PS. А вот REINDEX я не пробовал, но апдейты в базу проходят нормально. Пиши, как (не)получится чего...
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2002.04.29;
Скачать: [xml.tar.bz2];
Память: 0.44 MB
Время: 0.005 c