0

我正在尝试按包含 DBNull 值的列对 DataGridView 控件进行排序。此 DataGridView 控件绑定到 SQL Server 2012 数据库。

当我单击标题单元格(按升序排序)时,DBNull 值排在其余整数值之前,因此列中的顶部行都是空白的,然后是整数值 1,2, 3等按升序排列。

我该如何解决这个问题?我宁愿 DataGridView 控件对具有顶部值的行进行排序,然后是 DBNulls。

我试图在空白单元格中插入一个更高的值,然后对它们进行正确排序,但是当我将这些值返回给 System.DBNull.value 时,排序顺序会恢复到上面的方式。

我的代码如下:

If dgv.Columns(e.ColumnIndex).Name.EndsWith("Position") Then
    intSortingRunningPosition = 1000
    dgv.Sort(baseColumn, System.ComponentModel.ListSortDirection.Ascending)
    newColumn.HeaderCell.SortGlyphDirection = Windows.Forms.SortOrder.Ascending
    For Each dr As DataGridViewRow In dgv.Rows
        If dr.Cells(e.ColumnIndex).Value Is System.DBNull.Value Then 
            dr.Cells(e.ColumnIndex).Value = intSortingRunningPosition
            intSortingRunningPosition += 1
        End If
    Next
    dgv.Sort(newColumn, System.ComponentModel.ListSortDirection.Ascending)
    For Each dr As DataGridViewRow In dgv.Rows
        If dr.Cells(e.ColumnIndex).Value >= 1000 Then
            dr.Cells(e.ColumnIndex).Value = System.DBNull.Value
        End If
    Next
End If

对不起,如果这令人困惑。谢谢!

更新:

我已经修改了我的代码以使用 IComparer 方法,并提出了以下内容:

 Public Function Compare(ByVal x As Object, ByVal y As Object) As Integer _
     Implements System.Collections.IComparer.Compare

     Dim DataGridViewRow1 As DataGridViewRow = CType(x, DataGridViewRow)
     Dim DataGridViewRow2 As DataGridViewRow = CType(y, DataGridViewRow)
     Dim CompareResult As Integer
     Dim intDGV1Cell0Value As Integer = Nothing
     Dim intDGV1Cell1Value As Integer = Nothing
     Dim intDGV2Cell0Value As Integer = Nothing
     Dim intDGV2Cell1Value As Integer = Nothing

     Try
         intDGV1Cell0Value = CInt(DataGridViewRow1.Cells(0).Value)
     Catch ex As Exception
         intDGV1Cell0Value = Int32.MaxValue
     End Try
     Try
         intDGV1Cell1Value = CInt(DataGridViewRow1.Cells(1).Value)
     Catch ex As Exception
         intDGV1Cell1Value = Int32.MaxValue
     End Try
     Try
         intDGV2Cell0Value = CInt(DataGridViewRow2.Cells(0).Value)
     Catch ex As Exception
         intDGV2Cell0Value = Int32.MaxValue
     End Try
     Try
         intDGV2Cell1Value = CInt(DataGridViewRow2.Cells(1).Value)
     Catch ex As Exception
         intDGV2Cell1Value = Int32.MaxValue
     End Try

     ' Try to sort based on the Last Name column.
     CompareResult = System.String.Compare(intDGV1Cell1Value, intDGV2Cell1Value)

     ' If the Last Names are equal, sort based on the First Name. 
         If CompareResult = 0 Then
             CompareResult = System.String.Compare(intDGV1Cell0Value, intDGV2Cell0Value)
         End If

     Return CompareResult * sortOrderModifier
 End Function

空值现在根本不排序。关于我在这里做错了什么的任何想法?我敢肯定我有点不在场,因为它是......

4

2 回答 2

0

bit您可以向数据集添加一个名为 的字段NullValue,该字段适用于0不为空的数据列的任何条目,以及1任何为空的条目。

然后作为排序操作的一部分,按数据列本身和这个附加位列进行排序,这样空值自然会出现在排序中的非空值之后。

于 2013-01-08T15:59:09.663 回答
0

我使用 Sort(ICompare) 方法对该数据库进行排序是相当不成功的,因为它已绑定到外部数据集。我最终修改了我的连接字符串并重新填充了数据表。

我的代码如下:

If DataType = "Integer" Then
    If Column = "Vehicle Number" Then
        strConnectionStringCase = "Select * From Timing ORDER BY CAST([Class] AS NVARCHAR(MAX)) " & Direction & ", CONVERT(int, RTRIM(CAST([" & Column & "] AS NVARCHAR(MAX)))) " & Direction
    End If        
ElseIf DataType = "DateTime" Then
    strConnectionStringCase = "Select * From Timing ORDER BY CASE WHEN [" & Column & "] is NULL THEN 1 ELSE 0 END, [" & Column & "] " & Direction
ElseIf DataType = "String" Then
    If Column = "Vehicle Number" Then
        strConnectionStringCase = "Select * From Timing ORDER BY LEN(CAST([" & Column & "] AS NVARCHAR(MAX))) " & Direction & ", CAST([Class] AS NVARCHAR(MAX)) " & Direction & ", CAST([" & Column & "] AS NVARCHAR(MAX)) " & Direction
    End If
End If

我在标题单元格单击事件上调用此子例程。我将列名、排序方向和数据类型发送到此子例程。

此代码还允许我根据数据类型对列进行排序。如果有字母数字字符串,我可以按照类似的顺序对它们进行排序,就好像它们只是整数一样。DBNull 值始终放在排序的末尾。

谢谢您的帮助!

于 2013-01-28T19:22:13.107 回答