MySQL 选择响应大小 .NET

标签 mysql .net database vb.net response

是否可以在读取 MySQL 响应之前接收其大小?能够有一个进度条来显示有关接收过程的状态。

Public Function QUERY(ByVal queryString As String, ByVal connection As MySqlConnection)
Try
    Dim newQuery As String() = Split(queryString, ":")
    For Each Query In newQuery
        Dim cmd As New MySqlCommand(Query, connection)
        Dim reader As MySqlDataReader
        reader = cmd.ExecuteReader()
        While reader.Read()
        End While
        reader.Close()
    Next
Catch ex As Exception
    console("Error: " & ex.Message)
    Return ex.Message
End Try
Return ""
End Function

最佳答案

不,使用 DataReader,在到达读取器末尾之前,您无法知道查询返回的记录数。但是,您可以在查询中使用多个语句,其中第一个语句是数据计数。

这是一个可能的示例:

using con = new MySqlConnection("your_connection_string")
    con.Open()
    Dim cmd As MySqlCommand = new SqlCommand("SELECT COUNT(*) FROM MyTable;" & _
                                             "SELECT * FROM MyTable", con)
    Dim dr as MySqlDataReader = cmd.ExecuteReader()
    if dr.HasRows Then        
        dr.Read()
        Dim count = Convert.ToInt32(dr(0))
        Console.WriteLine("Reading:" & count.ToString() & " records")
        dr.NextResult()
        while dr.Read()
            Console.WriteLine("Record:" + dr(dr.GetOrdinal("TableID")).ToString())
        End While
    End if
End Using

关于MySQL 选择响应大小 .NET,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18132785/

相关文章:

mysql - 需要在具有开始日期和结束日期的选定日期之间按天列出活跃客户列表(也为空)

c# - 是否有实现异步游戏引擎循环的最佳实践?

sql - Postgres array_agg 一行中新字符串的每个值

c# - XmlSerializer : The string '' is not a valid AllXsd value

c# - 如何在不同线程中使用 Entity Framework ?

database - 用于本地主机开发的 DB2 的免费替代品

MYSQL inner join insert 多张表

mysql - 如何将mySQL的结果从行呈现到列?

php - 准备好的语句和二阶 SQL 注入(inject)

.net - 使用 Visual Studio 2008 创建数据库