Solved

Form based on a table with a check box field, need select all

Posted on 2015-01-08
5
115 Views
Last Modified: 2015-01-09
I have a table that opens in a form, it is a list of parts in an inventory database.  I use it to relieve inventory for an assembly when we are pulling parts from the crib to build.  You need to select the parts in the assembly you are pulling, most of the time you want to select all, there are times when you would pick only a few parts.  I would like a button at the top of the form "Select All", would be nice if you hit it a second time, it "Un-Selects All".  This is a field in a table.  I tried to attach query to the button, but then I will have to refresh the form etc..  Looking for the best way to do it.  I am using MS Access 2013.
0
Comment
Question by:Smilesxl
  • 3
  • 2
5 Comments
 
LVL 47

Expert Comment

by:Dale Fye (Access MVP)
ID: 40538580
easiest way is to write a query.  I have a button cmd_Select which has a caption which changes after each click.

Private Sub cmd_Select_Click

    Dim bSelect as Boolean
    Dim strSQL as string

    bSelect = (me.cmd_Select.Caption = "Select All")
    strSQL = "UPDATE [yourTable] SET [YourField] = " & bSelect
    currentdb.execute strsql, dbfailonerror
    me.cmd_Select.Caption = iif(bSelect, "Un-select All", "Select All")
    me.refresh   ' refreshes the form

End Sub

Open in new window

0
 
LVL 2

Author Comment

by:Smilesxl
ID: 40539355
That didn't work, tried this and this didn't work either.
Private Sub SelectAll_Click()
    Dim bSelect As Boolean
    Dim strSQL As String

    bSelect = (Me.SelectAll_Click.Caption = "Select All")
    strSQL = "UPDATE [Part List] SET [PICK] = Yes"
    CurrentDb.Execute strSQL, dbFailOnError
    Me.SelectAll_Click.Caption = IIf(bSelect, "Un-select All", "Select All")
    Me.Refresh   ' refreshes the form

End Sub
0
 
LVL 2

Author Comment

by:Smilesxl
ID: 40540003
Also, the field is a yes/no field, with a check box display control.  The field name is "PICK"
0
 
LVL 47

Accepted Solution

by:
Dale Fye (Access MVP) earned 500 total points
ID: 40540037
Yes/No fields are boolean and should accept True/False as well as -1/0 as values
This should work:

Private Sub cmd_Select_Click

    Dim bSelect as Boolean
    Dim strSQL as string

    'This line determines the caption of the Select button at the current time
    bSelect = (me.cmd_Select.Caption = "Select All")
    
    'The next two lines should update the field
    strSQL = "UPDATE [Part List] SET [Pick] = " & bSelect
    currentdb.execute strsql, dbfailonerror

    'Change the caption
    me.cmd_Select.Caption = iif(bSelect, "Un-select All", "Select All")

    'refreshes the form
    me.refresh   

End Sub

Open in new window

0
 
LVL 2

Author Closing Comment

by:Smilesxl
ID: 40540097
Awesome, thank you.  =)
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

AutoNumbers should increment automatically, without duplicates.  But sometimes something goes wrong, and the next AutoNumber value is a duplicate.  This article shows how to recover from this problem.
Access developers frequently have requirements to interact with Excel (import from or output to) in their applications.  You might be able to accomplish this with the TransferSpreadsheet and OutputTo methods, but in this series of articles I will di…
Basics of query design. Shows you how to construct a simple query by adding tables, perform joins, defining output columns, perform sorting, and apply criteria.
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

749 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