以编程方式查找特定记录

  1. 使用DoCmd对象的FindRecord方法( 效率最低 -查找特定记录的最简单方法是为组合框创建一个事件过程,以反映通用查找过程的每个步骤。

    Private Sub cboFind_AfterUpdate()
      Application.Echo False 
      Me![EmployeeID].SetFocus 
      DoCmd.FindRecord cboFind 
      cboFind.SetFocus 
      Application.Echo True 
    End Sub 
  2. 使用DoCmd对象的ApplyFilter方法( 更有效 -一种更有效的方法是使用筛选器直接从窗体的记录集中选择记录。 Applyfilter方法使您可以将过滤器应用于表,表单或报表,以对表或表单或报表的基础记录集中的记录进行限制或排序。 您可以使用filtername参数将保存的查询指定为Filter,也可以在wherecondition参数中输入SQL Where子句。

    Private Sub cboFind_AfterUpdate()
      Dim strSQL As String 
      strSQL = "[EmployeeID] = " & Me![cboFind] 
      DoCmd.ApplyFilter wherecondition:= strSQL
    End Sub
  3. 使用RecordsetClone( 最有效 -这种方法是最有效的,并且使用Form的RecordsetClone来引用Form的Recordset。

    Private Sub cboFind_AfterUpdate()
      Dim strCriteria As String 
      Dim rst As DAO.Recordset 
      Set rst = Me.RecordsetClone   
      strCriteria  = "[EmployeeID] = " & Me![cboFind] 
      rst.FindFirst strCriteria 
      Me.Bookmark = rst.Bookmark
    End Sub

From: https://bytes.com/topic/access/insights/667899-finding-specific-record-programmatically

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值