如何取消非迭代BackGroundWorker

问题描述 投票:2回答:1

我在BackGroundWorker中有一个非迭代代码,因此我无法检查CancellationPendig。

代码如下。

Private Sub BgW1_DoWork(ByVal sender As System.Object, ByVal e As System.ComponentModel.DoWorkEventArgs) Handles BgW1.DoWork
        Try
            Dim conn As New MySqlConnection(My.Settings.MySQL_Cnn_Cfg)
            Dim Adp As New MySqlDataAdapter
            Dim TablaDatos As New DataTable

            conn.Open()

            Using cmd As New MySqlCommand()
                cmd.CommandType = CommandType.Text
                cmd.Connection = conn

                cmd.CommandText = e.Argument

                Adp.SelectCommand = cmd

                TablaDatos.Clear()
                Adp.Fill(TablaDatos)

                e.Result = TablaDatos
            End Using
        Catch ex As Exception
            e.Result = "Error!"
            e.Cancel = True
        End Try
End Sub

BackGroundWorker接收一个查询字符串并返回一个DataTable,如果远程服务器做出快速回答,它就可以工作,但是对于复杂的查询,我花了一些时间才能取消该过程,或者至少我不知道该怎么做。 >

我已经尝试过

BgW1.Dispose()

没有成功,因此还有另一种方法来停止BackGroundWorker?

我在BackGroundWorker中有一个非迭代代码,因此我无法检查CancellationPendig。代码如下。私人Sub BgW1_DoWork(ByVal发送者为System.Object,ByVal e为系统....

vb.net backgroundworker
1个回答
4
投票

不,你不能。

© www.soinside.com 2019 - 2024. All rights reserved.