4

我有一组包含在 Advantage Database 数据字典中的表。字典不再可用,表也不会打开。

我想使用代码(而不是 Advantage Data Architect)释放这些表。

我能找到的唯一参考是帮助中列出的一个名为 ADSDDFreeTable 的函数。

该函数的文档位于此链接:

http://devzone.advantagedatabase.com/dz/WebHelp/Advantage11.1/index.html?ace_adsddfreetable.htm

但它没有提供代码示例,我无法理解如何使用它。

任何人都愿意展示如何使用此函数的代码示例(使用变量,而不是文字,用于文件名等)

非常感谢!

4

2 回答 2

5

Ace.pas定义AdsDDFreeTable

function AdsDDFreeTable( pucTableName: PAceChar;
                         pucPassword: PAceChar ):UNSIGNED32; {$IFDEF WIN32}stdcall;{$ENDIF}{$IFDEF LINUX}cdecl;{$ENDIF}

相同的Ace.pas定义PAceChar

type
  PAceChar = PAnsiChar;

因此,对函数的调用应该相当简单:

var
  TableName: AnsiString;
begin
  TableName := 'C:\Data\MyTable.adt`;
  if AdsDDFreeTable(PAnsiChar(TableName), nil) <> ADS_FREETABLEFAILED then
    ShowMessage('Table removed from datadictionary')
  else
    // Call ADSGetLastError to retrieve reason for failure;
end;
于 2013-09-24T20:46:05.220 回答
5

除了@Ken 的解决方案 (+1),还有一个名为 freeadt.exe 的独立命令行实用程序,它将从关联的数据字典中释放 ADT 表。我相信它是与Advantage Data Architect一起安装的。

如果从不带参数的命令行运行它,它会显示使用信息。不过,一般来说,您可以给它一个文件夹名称(以处理所有表)或一个特定文件作为参数。

于 2013-09-24T22:22:44.980 回答