vb.net – 在Access和.NET中对数字进行排序

前端之家收集整理的这篇文章主要介绍了vb.net – 在Access和.NET中对数字进行排序前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个Access表,它有一个Number字段和一个Text字段.

我可以运行这样的查询

SELECT * FROM Table ORDER BY intID ASC
//outputs 1,2,3,10

但是当我尝试通过.NET OleDB客户端运行相同的查询时,如下所示:

Private Sub GetData()    
   Using cnDB As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Path)
        cnDB.Open()
        Dim sql As String = "SELECT * FROM Table ORDER BY intID ASC"
        Dim cmd As New OleDbCommand(sql,cnDB)
        Dim dr As OleDbDataReader = cmd.ExecuteReader()
        While dr.Read()
            lst.Items.Add(dr.Item("intID") & " - " & dr.Item("strName"))
        End While
        cnDB.Close()
    End Using
End Sub

我按顺序1,10,3获得物品.

这里发生了什么,我怎样才能在两个地方“自然地”(1,10)对数据进行排序?

解决方法

尝试

SELECT * FROM Table ORDER BY CInt(intID) ASC

明确告诉Access将其视为整数而不是字符串.显然,OleDbClient中的某些内容将此字段视为字符串(文本字段)并相应地进行排序.

猜你在找的VB相关文章