Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> ADP  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702064
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

组合框的行来源如何使用参数存储过程?

作者:cg1  摘自:access911.net  :cg1  更新日期:2005-9-25  浏览人次:

 

组合框的行来源中只能写存储过程名,无法加上参数,我们这里用值列表绕过次限制


Public Sub CreateP2Procedure()
'创建本示例需要用的参数存储过程
'表名和字段名请按你的实际情况填写

    Dim strSQL As String
    strSQL = "Create Procedure procCreateMyList(@P1 int =0,@P2 nvarChar(50)='') As SELECT field1 FROM tblTable1 WHERE field2 = @P1 and field3 like @P2"
    CurrentProject.Connection.Execute strSQL
End Sub


Private Sub Form_Open(Cancel As Integer)
'将本过程放在窗体的打开事件中,设定组合框的行来源

    Me.ComboBox.RowSourceType = "value list"
    Me.ComboBox.RowSource = GetRowSource("p2", 155, "%")
End Sub


Public Function GetRowSource(ByVal strCommandText As String, _
                      Optional ByVal varP1, _
                      Optional ByVal varP2, _
                      Optional ByVal varP3)
'本函数作用:
'将存储过程的执行结果转换为用分号分隔的值列表
'现在参数是 3 个,可以更改一下,用数组来代替

    Dim Rs As New ADODB.Recordset
    Dim cmd As New ADODB.Command
    Dim prm As ADODB.Parameter
    Const DELIM As String = ";"
    With cmd
        .ActiveConnection = CurrentProject.Connection
        .CommandText = strCommandText
        .CommandType = adCmdStoredProc
    End With
    
    If Not IsMissing(varP1) Then
        Set prm = cmd.CreateParameter("P1", _
                  adInteger, adParamInput, , varP1)
        cmd.Parameters.Append prm
    End If
    If Not IsMissing(varP2) Then
        Set prm = cmd.CreateParameter("P2", _
                  adVarChar, adParamInput, 50, varP2)
        cmd.Parameters.Append prm
    End If
    If Not IsMissing(varP3) Then
        Set prm = cmd.CreateParameter("P3", _
                  adVarChar, adParamInput, 50, varP3)
        cmd.Parameters.Append prm
    End If
    
    Rs.Open cmd
    GetRowSource = ""
    If Not Rs.EOF Then
        GetRowSource = Rs.GetString(adClipString, , _
                  DELIM, DELIM)
    End If

End Function



本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利