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

时间:2011-08-29 17:11:00

标签: vb.net ms-access

我有一个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,2,3获得了物品。

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

3 个答案:

答案 0 :(得分:4)

尝试

SELECT * FROM Table ORDER BY CInt(intID) ASC

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

答案 1 :(得分:3)

我怀疑问题是你的连接字符串。如果您要连接到Access数据库并在连接字符串中包含IMEX=1,则提供程序会将所有数据视为string。因此,排序将按字符串值排序,为您提供1, 10, 2, 3,而不是将intID保留为整数,并按数字顺序排序。

答案 2 :(得分:0)

看起来你正在获得一个词汇(字母)顺序。如果数据库或查询中的某些内容认为是varchar / text列类型而不是数字类型,那么这将是正确的。