ADO.NET异步查询是什么

本篇内容介绍了“ADO.NET异步查询是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

ADO.NET数据库提供程序包含Connection、Command、DataAdapter和DataReader对象。在一般的ADO.NET编程中,首先要创建Connection对象,给它提供需要的信息,例如连接字符串。然后创建一个Command对象,给它提供要执行的SQL命令的细节。这个命令可以是内置的SQL文本命令、存储过程或对表的直接访问。如果需要,还可以为这些命令提供参数。

在创建Connection和Command对象后,就必须确定命令是否返回结果集。如果命令不返回结果集,就可以通过调用几个Execute方法之一,执行命令。另一方面,如果命令返回结果集,就必须确定是否要保留结果集,以备将来在不维持与数据库的连接的情况下使用。如果要保留结果集,就必须创建一个DataAdapter对象,用它填充DataSet或DataTable对象。这些对象可以在断开连接的模式下维护其中的信息。但是,如果不想保留结果集,只是要以快速方式执行命令,就可以使用Command对象创建DataReader对象。DataReader对象需要与数据库的实时连接,它是一个只向前的只读光标。下面我们来看一个关于使用ADO.NET异步查询的案例。

使用ADO.NET异步查询,并将查询结果呈现在指定的Form的DataGridView中

Public Class Asynchronous  Private Delegate Sub MainInvoke(ByVal TableItems() As String, ByVal RowCount As Integer) '委托  Delegate Sub AsyncMethodCaller()  Public connstr As String  Public cmdstr As String  Public frm As Form ' 指定的form  Public dgv As DataGridView ' 指定的datagridview  Public statuscontrol As Control ' 显示状态的控件  Public message As String'状态提示文本   Private Sub CallbackHandler()  Using conn As New SqlConnection(connstr), cmd As New SqlCommand(cmdstr, conn)  conn.Open()  Using reader As SqlDataReader = cmd.ExecuteReader  Dim i As Integer  Dim items(dgv.Columns.Count - 1) As String  While reader.Read()  For j As Int32 = 0 To dgv.Columns.Count - 1  items(j) = reader(dgv.Columns(j).HeaderText)  Next  frm.Invoke(New MainInvoke(AddressOf Addrows), items, i)  i += 1  End While  End Using  conn.Close()  End Using  End Sub   Public Sub getdatabase()  Dim caller As New AsyncMethodCaller(AddressOf CallbackHandler)  Dim result As IAsyncResult = caller.BeginInvoke(AddressOf StopRead, caller)  End Sub   Private Sub Addrows(ByVal TableItems() As String, ByVal row As Integer) '添加新行,并显示处理进度  dgv.Rows.Add()  For i As Int32 = 0 To TableItems.Length - 1  dgv.Rows(row).Cells(i).Value = TableItems(i)  Next  If statuscontrol IsNot Nothing Then statuscontrol.Text = message & row  End Sub   Private Sub StopRead(ByVal ar As IAsyncResult)  Dim caller As AsyncMethodCaller = CType(ar.AsyncState, AsyncMethodCaller)  caller.EndInvoke(ar)  End Sub  End Class

ADO.NET异步查询使用方法:

DataG.Columns.Add("编号", "编号")  DataG.Columns.Add("时间", "时间")  DataG.Columns.Add("用户名", "用户名")   Dim newselect As New Asynchronous  newselect.connstr = "SERVER=x;DATABASE=x;USER=x;PASSWORD=x;Asynchronous Processing=true" newselect.cmdstr = "select * from log" newselect.frm = Me newselect.dgv = DataG newselect.statuscontrol = Me newselect.message = "数据检索中..." newselect.getdatabase()

“ADO.NET异步查询是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注蜗牛博客网站,小编将为大家输出更多高质量的实用文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论电报频道链接