本篇内容介绍了“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异步查询是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!