3

我有一个使用基于 tdataset 的 tdbf 的 delphi 应用程序,其优点是不需要 bde 引擎。我需要对表进行排序,我通过添加一个 indexdef 然后指定 indexfieldnames 来对单个字段进行排序。

我现在正试图让它在 2 个字段上排序,即将男性分组在一起,然后将女性分组,然后将每个组按薪水排序,这样我们就可以看到女性从最低收入到最高收入,然后以同样的方式跟随男性。

我已经阅读了所有材料,说明您只需将 indexdef 的排序字段指定为“性别+薪水”。当我尝试使用索引时,我被告知“+”不是有效的字段名。我已经尝试了'.'的每个分隔符。','。'&' 和 ';'。每个分隔符都被视为一个不存在的字段。在多个字段上对表格进行排序的正确方法是什么?

在此先感谢克林顿英国人

4

2 回答 2

4

xBASE(dBASE 及其衍生产品)要求索引中的字段全部转换为相同的数据类型,通常是字符串。为此,通常需要一些常用功能:

  • DTOS() - 将 xBASE 日期转换CCYYMMDD为字符串格式
  • STR() - 将数字转换为字符串,带有可选的宽度说明符(默认为 10)和小数点右侧的位数。具体来说,语法被指定为STR(<numeric> [, <width> [, <decimaldigits>] ]).
  • SUBSTR() - 从另一个字符串中提取一部分,具有指定的起始位置和字符数
  • IIF() - 立即 IF,用于转换逻辑(例如,IIF(Married = .T., 'Y', 'N')

索引表达式确实与+运算符结合在一起。您收到的错误可能是因为您尚未转换为通用数据类型。

当您指定Gender列(可能定义为CHAR 1)和Salary列(可能是NUMERIC某种大小)时,您可以使用类似

Dbf1.AddIndex('GENDER_SAL', 'GENDER + STR(SALARY, 10, 0)', []);

F 10000这会在, , 之类的表达式上创建一个索引F 200000M 12000其中SALARY将转换为 10 个字符的默认宽度(左填充空格)并且没有十进制数字。这应该适合你。

于 2013-01-16T01:44:15.937 回答
1

我没有使用过该组件,但看起来他们想要使用类似于我们在 dBase III 中使用的索引表达式。在文档的 PDF 版本的第 7 页,他们在表达式主题下提供了一个示例:

Dbf1. AddIndex('INDEX1 ', 'DTOS( DATEFIELD)+ SUBSTR ( LONGFIELD ,1 ,10)+ SUBSTR
( LONGFIELD2 ,1 ,20)', []);

您可以使用包含整个字符串的参数在您的字段上尝试他们的 SubStr 函数,看看是否至少可以为您提供结果。

于 2013-01-15T23:01:09.120 回答