gpt4 book ai didi

mysql - phpmyadmin 和 vb.net 上的相同查询得到不同的结果

转载 作者:行者123 更新时间:2023-11-29 02:40:02 28 4
gpt4 key购买 nike

我在直接使用 phpmyadmin 和在 vb.net 上得到不同的查询结果。

我使用了这个查询SELECT * FROM tbllocation WHERE loc_name LIKE '%ROOM%'

这是 phpmyadmin 和数据库服务器版本:

Here's the phpmyadmin and database server version.

以下是 phpmyadmin 的结果:

Here are the results from phpmyadmin

来自 vb.net 的结果:

Results from vb.net

这是我在 vb.net 中获取和显示查询结果的代码。

 cmd.CommandText = q
dr = cmd.ExecuteReader
Dim rowindex As Integer = 0
If dr.Read Then
While dr.Read
MsgBox(dr(1))
DataGridView1.Rows.Add(dr(1), dr(2), "", "")
DataGridView1.Rows(rowindex).Tag = dr(0)
rowindex += 1
End While
End If
dr.Close()

最佳答案

每次调用 Read 都会前进到下一条记录。在使用任何数据之前,您调用了两次 Read,因此您丢弃了第一条记录。如果您想要一个 If 语句,那么测试 HasRows,而不是 Read。也就是说,如果您没有 Else 来执行特定操作(如果没有记录),则 If 语句毫无意义。事实上,您的 While 循环会完成您需要的一切。

编辑:事实上,我也建议摆脱循环。创建一个DataTable并调用其Load方法将数据读取器的内容加载到其中,然后将DataTable绑定(bind)到网格。

编辑:更进一步,您似乎正在编辑数据,在这种情况下,我建议根本不要使用数据读取器。使用数据适配器填充 DataTable,将其绑定(bind)到网格(最好通过 BindingSource),对 DataTable 进行更改,然后使用相同的数据适配器保存更改。您当前为保存更改所做的任何操作只会使事情复杂化。

关于mysql - phpmyadmin 和 vb.net 上的相同查询得到不同的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54758473/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com