Passing a TempVar to a Combo box form

Posted on 2016-10-18
Medium Priority
Last Modified: 2016-10-19
In MS Access 2010 I am opening a single record form from another form with a button and passing a filter for the form with the button. That works fine. I also have a Combo box on the target form that I would like to populate with all the target forms filtered record set keys in order to allow the user to "jump" to the next record of choice rather than have to review the records sequentially.

So I am sending the Combo box query, select criteria as a TempVar. The Combo box query has a where clause, WHERE column IN ( [TempVars]![ComboFilterVariable] ). I pass this value, '("Active","On-Hold")' in one of the first forms SetTempVar to the target form.

When I replace the TempVar in the where clause with the value in TempVar which is ("Active","On-Hold"), assume the single quotes are removed by Access, the query works. But the query is not resolving the TempVar correctly as I get no rows using the TempVar in the query.

If I hard code the values the combo box it works. So not a combo box issue. I am using the same form with multiple filters so would really like to dynamically create the Combo box list to match the records provided by the filtered form rather than have multiple forms to display the same data for various lists.

Any help would be welcome, spent weeks on this on and off already.  
I am a beginner at macros and novice at MS Access.
Question by:Dave Harrison
  • 2
LVL 41

Accepted Solution

PatHartman earned 2000 total points
ID: 41848843
The In() list is not something that can be dynamically changed.  You have to create the list and concatenate it into the SQL String and then pass the completed string as an argument.

So Where Somefield In(Tempvars!somefield)

actually needs to be passed as:

Where Somefield In("Active","On-Hold")

This is code in a form that builds the necessary SQL string and uses it to replace the RecordSource.  You can use it to replace the RowSource of your combo.
Private Sub cmdFilter_Click()
On Error GoTo Err_cmdFilter_Click
    Dim i As Variant
    Dim strIN As Variant
    Dim strSQL As String
    strIN = ""
    For Each i In lstSelect.ItemsSelected
        strIN = strIN & lstSelect.ItemData(i) & ","
    Next i
    strIN = Left(strIN, Len(strIN) - 1) ' remove trailing comma.
    strSQL = "Select * From AccessAndJetErrors Where ErrorCode IN(" & strIN & ");"
    Me.RecordSource = strSQL

    Exit Sub

Select Case Err.Number
    Case 5
        MsgBox "Please select 1 or more items from the listbox", vbOKOnly
    Case Else
        MsgBox Err.Number & "-" & Err.Description
End Select
Resume Exit_cmdFilter_Click
End Sub

Open in new window

You can actually build the SQL string this way:

strSQL = "Select fld1, fld2, From YourTable Where Somefield In(" & Tempvars!somefield & ");"  The point is that VBA needs to resolve the Tempvar in this case since it is a string of strings rather than a simple string.

Author Closing Comment

by:Dave Harrison
ID: 41850306
Thank you so much
LVL 41

Expert Comment

ID: 41850467
You're welcome.

Featured Post

Get 10% Off Your First Squarespace Website

Ready to showcase your work, publish content or promote your business online? With Squarespace’s award-winning templates and 24/7 customer service, getting started is simple. Head to Squarespace.com and use offer code ‘EXPERTS’ to get 10% off your first purchase.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Explore the ways to Unlock VBA Project Password Excel 2010 & 2013 documents. Go through the article and perform the steps carefully to remove VBA Excel .xls file.
A quick solution showing how to control and open a POS Cash Register Drawer using VBA with MS Access.
The view will learn how to download and install SIMTOOLS and FORMLIST into Excel, how to use SIMTOOLS to generate a Monte Carlo simulation of 30 sales calls, and how to calculate the conditional probability based on the results of the Monte Carlo …
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…

607 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question