我有一个Access表,它有一个Number字段和一个Text字段. 我可以运行这样的查询: SELECT * FROM Table ORDER BY intID ASC//outputs 1,2,3,10 但是当我尝试通过.NET OleDB客户端运行相同的查询时,如下所示:
我可以运行这样的查询:
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)对数据进行排序?
尝试SELECT * FROM Table ORDER BY CInt(intID) ASC
明确告诉Access将其视为整数而不是字符串.显然,OleDbClient中的某些内容将此字段视为字符串(文本字段)并相应地进行排序.
