Multiple Selection List Boxes

  • Thread starter Thread starter Sandra
  • Start date Start date
S

Sandra

I want to make a form to use as an order sheet and will
need to be able to make several selections from each list
of products. I am using a list box, but Access Bible
tells me that I need to define a program by using Visual
Basic for Applications to capture the selections. Any
help/suggestions out there?
 
Hi Sandra

A multi-select listbox has a collection called ItemsSelected. You can
enumerate the members of that collection using VBA code. I guess you have a
command button for the user to click after the products have been selected,
so the code should go in the Click event procedure of that command button.
For example:

Private Sub cmdSubmitOrder_Click()
Dim vItem as Variant, lOrderID as Long
'
' insert code to create order header record
' and ascertain lOrderID
'
' now add an OrderItems record for each selected product
'
For Each vItem in lstSelectProducts.ItemsSelected
CurrentDb.Execute "Insert into OrderItems (OrderID, ProductID) " _
& "values (" & lOrderID & ", " _
& lstSelectProducts.ItemData(vItem) & ")"
Next vItem
End Sub
 
I want to make a form to use as an order sheet and will
need to be able to make several selections from each list
of products. I am using a list box, but Access Bible
tells me that I need to define a program by using Visual
Basic for Applications to capture the selections. Any
help/suggestions out there?

A Subform (see the Northwind sample database Orders form for an
example) is really a lot easier for this - no VBA code required.

If you really want to use the listbox approach, here's some sample
code you can adapt:

Private Sub cmdProcess_Click()
' Comments : Update the AnimalCondition table based on the
' selections in
' the unbound multiselect listbox lstHealthIssues.
' Newly selected rows will be added to the table,
' newly cleared
' rows will be deleted.
' Parameters: None
' Modified : 01/29/02 by JWV
'
' --------------------------------------------------
' Populate the AnimalCondition table with the selected issues
On Error GoTo PROC_ERR

Dim iItem As Integer
Dim lngCondition As Long
Dim db As DAO.Database
Dim rs As DAO.Recordset

' save the current record if it's not saved
If Me.Dirty = True Then
Me.Dirty = False
End If
Set db = CurrentDb
' Open a Recordset based on the table
Set rs = db.OpenRecordset("AnimalCondition", dbOpenDynaset)
With Me!lstHealthIssues
' Loop through all rows in the Listbox
For iItem = 0 To .ListCount - 1
lngCondition = .Column(0, iItem)
' Determine whether this AnimalID-HealthID combination is
' in the table
rs.FindFirst "[AnimalID] = " & Me.AnimalID & " AND " _
& "[HealthIssueID] = " & lngCondition
If rs.NoMatch Then ' this item has not been added
If .Selected(iItem) Then
' add it
rs.AddNew
rs!AnimalID = Me.AnimalID
rs!HealthIssueID = lngCondition
rs.Update
End If ' if it wasn't selected, ignore it
Else
If Not .Selected(iItem) Then
' delete this record if it's been deselected
rs.Delete
End If ' if it was selected, leave it alone
End If
Next iItem
End With
rs.Close
Set rs = Nothing
Set db = Nothing
Me.subAnimalCondition.Requery

PROC_EXIT:
Exit Sub

PROC_ERR:
MsgBox "Error " & Err.Number & " in cmdProcess_Click:" _
& vbCrLf & Err.Description
Resume PROC_EXIT

End Sub
 
Back
Top