VB中Execute的用法

32 篇文章 0 订阅

VB中Execute是指ADO命令之一:Execute 方法。

  • Execute 方法,执行在 CommandText 属性中指定的查询、SQL 语句或存储过程。

    语法

    对于按行返回的 Command:

    Set recordset = command.Execute(
    RecordsAffected, Parameters, Options
    )

    对于不按行返回的 Command:

    command.Execute RecordsAffected,
    Parameters, Options

    返回值

    返回 Recordset 对象引用。

    参数

    RecordsAffected    可选,长整型变量搜索,提供者向其返回操作所影响的记录数目。

    Parameters    可选,变体型数组,使用 SQL
    语句传送的参数值。(用该参数传送时输出参数将不返回正确值。)

  • CommandText 属性 (ADO),包含要发送给提供者的命令的文本。

  • Execute、Requery 和 Clear 方法范例

    该范例演示运行来自 Command 对象和 Connection 对象的 Execute 方法。同时使用
    Requery 方法检索记录集中的当前数据,并用 Clear 方法清除 Errors 集合的内容。运行该过程需要
    ExecuteCommand 和 PrintOutput 过程。

    Public Sub ExecuteX()

      Dim strSQLChange As String
      Dim strSQLRestore As String
      Dim strCnn As String
      Dim cnn1 As ADODB.Connection
      Dim cmdChange As ADODB.Command
      Dim rstTitles As ADODB.Recordset
      Dim errLoop As ADODB.Error

      ' 定义两个 SQL 语句作为命令文本执行。
      strSQLChange = "UPDATE Titles SET Type = " & _
         "'self_help' WHERE Type = 'psychology'"
      strSQLRestore = "UPDATE Titles SET Type = " & _
         "'psychology' WHERE Type = 'self_help'"

      ' 打开连接。
         strCnn = "Provider=sqloledb;" & _
         "Data Source=srv;Initial Catalog=pubs;User Id=sa;Password=; "
      Set cnn1 = New ADODB.Connection
      cnn1.Open strCnn

      ' 创建命令对象。
      Set cmdChange = New ADODB.Command
      Set cmdChange.ActiveConnection = cnn1
      cmdChange.CommandText = strSQLChange
     
      ' 打开标题表。
      Set rstTitles = New ADODB.Recordset
      rstTitles.Open "titles", cnn1, , , adCmdTable

      ' 打印原始数据报告。
      Debug.Print _
         "Data in Titles table before executing the query"
      PrintOutput rstTitles

      ' 清除 Errors 集合的外部错误。
      cnn1.Errors.Clear

      ' 调用 ExecuteCommand 子例程执行 cmdChange 命令。
      ExecuteCommand cmdChange, rstTitles
     
      ' 打印新数据报告。
      Debug.Print _
         "Data in Titles table after executing the query"
      PrintOutput rstTitles

      ' 使用 Connection 对象的 execute 方法执行 SQL 语句以恢复数据。
      ' 捕获错误,必要时检查 Errors 集合。
      On Error GoTo Err_Execute
      cnn1.Execute strSQLRestore, , adExecuteNoRecords
      On Error GoTo 0

      ' 通过再查询记录集检索当前数据。
      rstTitles.Requery

      ' 打印已恢复数据的报告。
      Debug.Print "Data after executing the query " & _
         "to restore the original information"
      PrintOutput rstTitles

      rstTitles.Close
      cnn1.Close
     
      Exit Sub
     
    Err_Execute:

      ' 将任何由执行查询引起的错误通知用户。
      If Errors.Count > 0 Then
         For Each errLoop In Errors
            MsgBox "Error number: " & errLoop.Number & vbCr & _
               errLoop.Description
         Next errLoop
      End If
     
      Resume Next

    End Sub

    Public Sub ExecuteCommand(cmdTemp As ADODB.Command, _
      rstTemp As ADODB.Recordset)

      Dim errLoop As Error
     
      ' 运行指定的 Command 对象。捕获错误,必要时检查 Errors 集合。
      On Error GoTo Err_Execute
      cmdTemp.Execute
      On Error GoTo 0

      '通过再查询记录集检索当前数据。
      rstTemp.Requery
     
      Exit Sub

    Err_Execute:

      ' 将任何由执行查询引起的错误通知用户。
      If Errors.Count > 0 Then
         For Each errLoop In Errors
            MsgBox "Error number: " & errLoop.Number & vbCr & _
               errLoop.Description
         Next errLoop
      End If
     
      Resume Next

    End Sub

    Public Sub PrintOutput(rstTemp As ADODB.Recordset)

      ' 枚举 Recordset。
      Do While Not rstTemp.EOF
         Debug.Print "  " & rstTemp!Title & _
            ", " & rstTemp!Type
         rstTemp.MoveNext
      Loop

    End Sub


 

zdingyun V2 | 工程师 向TA咨询

擅长: IT

其他回答


首先:Imports System.Runtime.InteropServices 然后: Private Declare Function EbExecuteLine Lib "VBA6.DLL" (ByVal pStringToExec As Long, ByVal Unknownn1 As Long, ByVal Unknownn2 As Long, ByVal fCheckOnly As Long) As Long ' <DllImport("VBA6.DLL", EntryPoint:="EbExecuteLine", SetlastError:=True, CharSet:=CharSet.Unicode, ExactSpelling:=True, CallingConvention:=CallingConvention.StdCall)> Public Shared Function EbExecuteLine(ByVal pStringToExec As Long, ByVal Unknownn1 As Long, ByVal Unknownn2 As Long, ByVal fCheckOnly As Long) As Long '<DllImport("D:\vba6.dll", CharSet:=CharSet.Ansi, SetlastError:=True)> Public Shared Function EbExecuteLine(ByVal pStringToExec As Long, ByVal Unknownn1 As Long, ByVal Unknownn2 As Long, ByVal fCheckOnly As Long) As Long 'End Function '<DllImport("vba6.dll", CharSet:=CharSet.Ansi, SetlastError:=True)> 'Public Shared Function EbExecuteLine(ByVal pStringToExec As Long, ByVal Unknownn1 As Long, ByVal Unknownn2 As Long, ByVal fCheckOnly As Long) As Long 'End Function '定义StrPtr函数,实现获取字符串地址功能 Private Function StrPtr(ByVal e As Object) As Int32 Dim GC As System.Runtime.InteropServices.GCHandle = System.Runtime.InteropServices.GCHandle.Alloc(e, System.Runtime.InteropServices.GCHandleType.Pinned) Dim GC2 As Int32 = GC.AddrOfPinnedObject.ToInt32 GC.Free() Return GC2 End Function Function ExecuteLine(ByVal sCode As String, Optional ByVal fCheckOnly As Boolean = True) As Boolean ExecuteLine = EbExecuteLine(StrPtr(sCode), 0, 0, 0) End Function Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click Dim dm() As String Dim i As Long dm = Split(TextBox.Text, ";") For i = 0 To UBound(dm) If Len(dm(i)) <> 0 Then Dim Result As Boolean Result = ExecuteLine(dm(i)) If Result = False Then Debug.Print(i + 1 & vbTab & "行执行错误") Else Debug.Print(i + 1 & vbTab & "行代码错误") End If Next End Sub
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值