设为首页 友情链接
在线留言 发表文章
加入收藏 广告联系

刺猬首页

| 专案技术 | 网络技术 | 图形图象 | 网络编程 | 网页设计 | 操作系统 | 服务器 | 技术白皮书 | 在线实验室 | 刺猬论坛 |
  | 数据库 | 设计赏析 | 存储频道 | 网络安全 | 私服架设 |  Solaris | 网站评估 | PC维护技巧 | 下载中心 | 博 客 |
专题: | Linux | java | cisco | 防病毒 | 刀片 | SOA | iscsi | ASP.NET | SQL | Oracle |
您现在的位置: IT公社 IT community >> 数据库应用 >> ACCESS >> 教程正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
在Oracle的网络结构中解…
Oracle中使用自治事务保…
Oracle Freelist和HWM原…
在Oracle里设置访问多个…
一个生成Oracle用户密码…
Oracle数据库全文索引查…
利用外部命令Oralce数据…
SQL链接Oracle,数据长度…
Oracle函数之常见的单行…
SQL 2005的SSIS与Oracle…
  ACCESS ADP组合框的行来源如何使用参数存储过程           
ACCESS ADP组合框的行来源如何使用参数存储过程
 

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

频道声明:本频道的文章除部分特别声明禁止转载的专稿外,可以自由转载.但请务必注明出出处和原始作者 文章版权归本频道与文章作者所有.对于被频道转载文章的个人和网站,我们表示深深的谢意。

原始作者:佚名 录入时间:2006-9-11
信息来源:不详 投稿信箱:itqoo@126.com
教程录入:admin    责任编辑:admin 
  • 上一个教程:

  • 下一个教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    - 关于我们 - 合作伙伴 - 友情链接 - 广告刊登 - 投稿热线 - 在线留言版权声明联系方式 -
    IT公社版权所有 粤ICP备05127012号
    Copyrigh@2005-2006 itqoo.com.Inc All Rights Reserved  推荐分辨率 1024*768
    联系站长:E-Mail:itqoo@126.com     MSN:urchincc@hotmail.com    QQ:点击这里给我发消息
    特别感谢:亿太网络提供空间支持