vb.net – 在Access和.NET中对数字进行排序
发布时间:2020-12-17 07:30:33 所属栏目:百科 来源:网络整理
导读:我有一个Access表,它有一个Number字段和一个Text字段. 我可以运行这样的查询: SELECT * FROM Table ORDER BY intID ASC//outputs 1,2,3,10 但是当我尝试通过.NET OleDB客户端运行相同的查询时,如下所示: Private Sub GetData() Using cnDB As New OleDbCon
我有一个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中的某些内容将此字段视为字符串(文本字段)并相应地进行排序. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |