2

我有一长串要在网格中排序的字符串值。最初,默认排序算法用于整个网格。但是,我最终不得不重写网格的排序,因为有几列需要特殊排序,而网格不允许对特定列进行自定义排序。这里有问题的列不需要特殊排序,所以我只使用了 CompareTo:

Public Function Compare(ByVal p1 as MyObj, ByVal p2 as MyObj) As Integer
    Return p1.Description.CompareTo(p2.Description)
End Function

比较默认的网格排序方法和我现在用 CompareTo 使用的方法,我得到了完全相同的结果。但是,直接数据库查询的排序结果不同(根据我认为应该是正确的数据库结果)。

以下是我认为不正确的排序结果的三个示例:

示例 1

排序结果:

  1. 测试 - A/A 我的测试
  2. TEST1000 测试
  3. TEST1000 测试
  4. 测试一个测试
  5. 测试-B/A 我的测试

预期结果:

  1. 测试 - A/A 我的测试
  2. 测试-B/A 我的测试
  3. TEST1000 测试
  4. TEST1000 测试
  5. 测试一个测试

示例 2

排序结果:

  1. 测试 - 一个测试
  2. 考验我
  3. 测试-#1 A
  4. 测试-#1 B

预期结果:

  1. 考验我
  2. 测试 - 一个测试
  3. 测试-#1 A
  4. 测试-#1 B

示例 3

排序结果:

  1. 路易丝测试 1
  2. 路易丝测试 2
  3. 路易- 测试 1

预期结果:

  1. 路易- 测试 1
  2. 路易丝测试 1
  3. 路易丝测试 2

有没有人遇到过这个或者有任何想法可能发生在这里?

4

1 回答 1

2

CompareTo进行区分大小写、区分区域性的排序,因此撇号、连字符等字符不会显示严格字符编码排序中的位置——这似乎是您所期望的。

考虑使用允许您将StringComparison指定为 Ordinal的Compare重载

于 2012-08-14T22:35:25.450 回答