我有一个很长的字符串值列表,我试图在网格中排序。最初,默认排序算法用于整个网格。但是,我不得不重写网格的排序,因为有几个列需要特殊的排序,而且网格不允许对特定列进行自定义排序。这里讨论的列不需要特殊排序,所以我只使用了CompareTo:
Public Function Compare(ByVal p1 as MyObj, ByVal p2 as MyObj) As Integer
Return p1.Description.CompareTo(p2.Description)
End Function比较默认的网格排序方法和我现在使用的与CompareTo的方法,我得到了完全相同的结果。但是,直接数据库查询的排序结果不同(根据我认为应该是什么,数据库结果是正确的)。
以下是我认为不正确的排序结果的三个例子:
示例1
排序结果:
预期结果:
示例2
排序结果:
预期结果:
示例3
排序结果:
预期结果:
以前有没有人遇到过这种情况,或者有什么想法吗?
发布于 2012-08-14 22:35:25
CompareTo进行区分大小写、区分区域性的排序,因此像撇号、连字符等字符不会显示在严格的字符编码排序中的位置--这似乎是您所期望的。
考虑使用比较的重载,使您可以将StringComparison指定为序号
https://stackoverflow.com/questions/11961053
复制相似问题