Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 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
6-94525
yaJohn
2002-02-13 15:56
2002.04.29
SOCKS5 server


1-94386
besen-ok
2002-04-17 12:00
2002.04.29
Как определить содана ли форма


1-94404
Roman9
2002-04-07 10:57
2002.04.29
Как запустить из одного exe-файла другой?


3-94298
Megera
2002-04-06 09:23
2002.04.29
заработная плата


4-94610
MARcoDEN
2002-02-19 20:20
2002.04.29
Аналог функции ExtractFileName





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский