ACC1x: How to Move List Box Selections to a Second List Box

Last reviewed: May 14, 1997
Article ID: Q97518
The information in this article applies to:
  • Microsoft Access versions 1.0, 1.1

SUMMARY

This article describes how to create a pair of list boxes to imitate the multiple selection behavior used in Microsoft Access wizards.

MORE INFORMATION

The example below demonstrates how to create a new form that contains two list boxes and three command buttons. You can add items to or delete items from the list using the command buttons or the properties of the list boxes:

  1. Create the following new table:

          Table: Table1
          -----------------------------------------------
          Field Name: List (primary key)
    
             DataType: Text
             Field Size: 15
             Caption: Items that will be provided in list
          Field Name: Selected
             DataType: Text
             Field Size: 5
             Caption: Indicates if the item has been selected
    
    

  2. View the table in Datasheet view. Add five records to the table. For each record, type any text in the List field (for example a list of colors or cities), and type "YES" (without quotation marks) in the Selected field.

  3. Create the following two new queries based on Table1:

          Query: Select Yes
          -------------------------------
          Field Name: List
    
             Show: Yes
             Criteria: [selected] = "YES"
    
          Query: Select No
          ------------------------------
          Field Name: List
             Show: Yes
             Criteria: [selected] = "NO"
    
    

  4. Enter the following three sample functions in a new or existing module:

          '=======================================================
          'The following function opens the table and changes the
          'selected value from YES to NO, and then executes the
          'query for the two list boxes so that they will display
          'the updated values.
          '=======================================================
          Function ADD ()
    
             Dim MyDB As Database
             Dim MyTable As Table
             Dim y As Control
    
             Set MyDB = CurrentDB()
             Set MyTable = MyDB.OpenTable("Table1")
             Set y = forms!SelectList!field0
    
             MyTable.index = "PrimaryKey"
             MyTable.Seek "=", y
    
             MyTable.Edit
             MyTable.[selected] = "no"
             MyTable.Update
    
             MyTable.Close
    
             DoCmd Requery "field0"
             DoCmd Requery "field1"
          End Function
    
          '=======================================================
          'The following function opens the table and changes the
          'selected value from NO to YES, and then executes the
          'query for the two list boxes so that they will display
          'the updated values.
          '=======================================================
          Function Del ()
             Dim MyDB As Database
             Dim MyTable As Table
             Dim y As Control
    
             Set MyDB = CurrentDB()
             Set MyTable = MyDB.OpenTable("Table1")
             Set y = forms!SelectList.field1
    
             MyTable.index = "primarykey"
             MyTable.Seek "=", y
             MyTable.Edit
             MyTable.[selected] = "yes"
             MyTable.Update
             MyTable.Close
    
             DoCmd Requery "field0"
             DoCmd Requery "field1"
          End Function
    
          '=======================================================
          'The following function sets all values in the Selected
          'field to YES, and then executes the query for the two
          'list boxes so that they will display the updated
          'values.
          '=======================================================
          Function Clear ()
             Dim MyDB As Database
             Dim MyTable As Table
    
             Set MyDB = CurrentDB()
             Set MyTable = MyDB.OpenTable("Table1")
    
             On Error GoTo erhandle
             MyTable.MoveFirst
    
             Do Until MyTable.EOF
                MyTable.Edit
                MyTable.[selected] = "yes"
                MyTable.Update
                MyTable.MoveNext
             Loop
    
          erhandle:
             Resume Next
    
             DoCmd Requery "field0"
             DoCmd Requery "field1"
          End Function
    
    

  5. Create the following new, unbound form, and then save it as SelectList:

          Object: list box
          -----------------------------
          ControlName: field0
    
             ControlSource:
             RowSourceType: Table/Query
             RowSource: Select Yes
             OnDblClick: =ADD()
    
          Object: list box
          -----------------------------
          ControlName: field1
             ControlSource:
             RowSourceType: Table/Query
             RowSource: Select No
             OnDblClick: =Del()
    
          Object: command button
          -----------------------
          ControlName: Button One
             Caption: Clear
             OnPush: =Clear()
    
          Object: command button
          -----------------------
          ControlName: Button Two
             Caption: Add item
             OnPush: =Add()
    
          Object: command button
          -------------------------
          ControlName: Button Three
             Caption: Delete item
             OnPush: =Del()
    
    
The first list box, Field0, displays the items to be selected. The second list box, Field1, displays the items that are selected.

REFERENCES

For more information about list boxes, search for "list box: creating" then "List Box Control" using the Microsoft Access Help menu.


Additional query words: listbox combo multiple fill function wizard
Keywords : FmsCmbo kbusage
Version : 1.0 1.1
Platform : WINDOWS
Hardware : X86
Issue type : kbhowto


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: May 14, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.