Solved

Passing a TempVar to a Combo box form

Posted on 2016-10-18
3
54 Views
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.
0
Comment
Question by:Dave Harrison
  • 2
3 Comments
 
LVL 34

Accepted Solution

by:
PatHartman earned 500 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_cmdFilter_Click:
    Exit Sub

Err_cmdFilter_Click:
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.
1
 

Author Closing Comment

by:Dave Harrison
ID: 41850306
Thank you so much
0
 
LVL 34

Expert Comment

by:PatHartman
ID: 41850467
You're welcome.
0

Featured Post

Enabling OSINT in Activity Based Intelligence

Activity based intelligence (ABI) requires access to all available sources of data. Recorded Future allows analysts to observe structured data on the open, deep, and dark web.

Join & Write a Comment

Many companies are making the switch from Microsoft to Google Apps (https://www.google.com/work/apps/business/). Use this article to learn more about what Google Apps has to offer and to help if you’re planning on migrating to Google Apps. It is …
The System Center Operations Manager 2012, known as SCOM, is a part of the Microsoft system center product that provides the user with infrastructure monitoring and application performance monitoring. SCOM monitors:   Windows or UNIX/LinuxNetwo…
What’s inside an Access Desktop Database. Will look at the basic interface, Navigation Pane (Database Container), Tables, Queries, Forms, Report, Macro’s, and VBA code.
The viewer will learn how to use the =DISCRINV command to create a discrete random variable, use this command to model a set of probabilities and outcomes in a Monte Carlo simulation, and learn how to find the standard deviation of a set of probabil…

708 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

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now