首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于向表单添加日期范围以改进搜索的VBA代码

用于向表单添加日期范围以改进搜索的VBA代码
EN

Stack Overflow用户
提问于 2018-06-28 06:56:19
回答 1查看 34关注 0票数 0

我已经有一个带有"Type“(这是我正在搜索的抗体字段记录)的Combo下拉列表的表单。"SearchRecords“按钮启动代码。我想在表单中添加开始和结束日期,以优化搜索。我已经为StartDateEndDate创建了日期文本框。我当前的代码如下所示。我需要VB代码的帮助来获得日期范围。

代码语言:javascript
复制
Private Sub SearchRecords_Click()
    Dim strSQL As String
    On Error Resume Next
    Combo24.SetFocus
    DoCmd.Hourglass True
    strSQL = "SELECT * FROM tblAGV_Log WHERE [Type] = '" & Me.Combo24.Text & "' Order by Date DESC"
    Me.RecordSource = ""
    Me.RecordSource = strSQL
    DoCmd.Hourglass False
End Sub
EN

回答 1

Stack Overflow用户

发布于 2018-06-28 07:58:14

展示它比描述它容易,但我会像这样扩展你的例程:

代码语言:javascript
复制
Private Sub SearchRecords_Click()
    Dim strSQL As String
    Dim strWhere As String
    Dim strOp As String

    On Error Resume Next

    DoCmd.Hourglass True
    strSQL = "SELECT * FROM tblAGV_Log"

    strWhere = ""
    strOp = ""
    If Not IsNull(Me.Combo24.Value) Then
        strWhere = strWhere & strOp & "([Type] = '" & Me.Combo24.Value & "')"
        strOp = " And "
    End If
    If Not IsNull(Me.StartDate.Value) Then
        strWhere = strWhere & strOp & "([Date] >= #" & Me.StartDate.Value & "#)"
        strOp = " And "
    End If
    If Not IsNull(Me.EndDate.Value) Then
        strWhere = strWhere & strOp & "([Date] <= #" & Me.EndDate.Value & "#)"
        strOp = " And "
    End If

    If Len(strWhere) > 0 then
        strSQL = strSQL & " WHERE " & strWhere
    End If
    strSQL = strSQL & " Order by [Date] DESC"

    Me.RecordSource = strSQL
    DoCmd.Hourglass False

End Sub

这将使您非常接近。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51072505

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档