如何使用VB.NET在Access数据库中实现数字排序功能?

2026-05-08 12:333阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计261个文字,预计阅读时间需要2分钟。

如何使用VB.NET在Access数据库中实现数字排序功能?

我有一个Access表,它包含一个Number字段和一个Text字段。我可以执行如下查询:SELECT * FROM Table ORDER BY intID ASC // outputs 1,2,3,10但是当我通过.NET OleDB客户端端运行相同的查询时,结果如下所示:1,2,3,10

我有一个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获得物品.

如何使用VB.NET在Access数据库中实现数字排序功能?

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

尝试

SELECT * FROM Table ORDER BY CInt(intID) ASC

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

本文共计261个文字,预计阅读时间需要2分钟。

如何使用VB.NET在Access数据库中实现数字排序功能?

我有一个Access表,它包含一个Number字段和一个Text字段。我可以执行如下查询:SELECT * FROM Table ORDER BY intID ASC // outputs 1,2,3,10但是当我通过.NET OleDB客户端端运行相同的查询时,结果如下所示:1,2,3,10

我有一个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获得物品.

如何使用VB.NET在Access数据库中实现数字排序功能?

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

尝试

SELECT * FROM Table ORDER BY CInt(intID) ASC

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