Go Premium for a chance to win a PS4. Enter to Win

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 321
  • Last Modified:

ListBox MS Access 2005

Not sure if this is do-able.

I have a listbox on my form that is populating correctly
I have a click event on the ListBox and am getting the value of column  (1)


Private Sub lbvHoursSID_Click()
    varHours = Me.lbvHoursSID.Column(1)
    Me.lblMessage.Caption = varHours
    blah...blah...blah...

Is there any way to set the value of column(5) on a different textbox update event?

Something like...
    Me.lbvHoursSID.Column(5) = Me.txtHours
0
lrbrister
Asked:
lrbrister
  • 4
  • 3
  • 2
1 Solution
 
Rey Obrero (Capricorn1)Commented:
first you have to set in the list box property
Column Count 5  ' the least number of columns you can have could be more

now you can use this
Me.txtHours = Me.lbvHoursSID.Column(5)


you can also specify the Column Widths
0
 
mbizupCommented:
Not directly like that.

To change a column value, you'd have to change the rowsource query, or change the value in the table that the rowsource is drawn from.

What is your overall goal for this idea?  Can you use a separate control to show this value instead of changing the column?
0
 
lrbristerAuthor Commented:
Here's my goal.
I have a listbox that loads the type of hours based on customer.

I can't have a jillion hours data entry boxes all over the form.

So...I want to click on the hours type description (unique per customer) and then enter the hours in a single text box.
When I tab off of that textbox, I want to store the value BACK in the hours column in the listBox.

You can see my controls below...
I'ts looking like I may have to feed these various values BACK into my recordset?
The other columns aren't visible.  The column I'm trying to set is the (5)

This is the SUB that sets the record set
Private Sub loadSID()
    Dim cmd As New ADODB.Command
    cmd.ActiveConnection = Conn
    cmd.CommandType = adCmdStoredProc
    cmd.CommandText = "usp_HoursTrackingSIDGet"
    Set Me.lbvHoursSID.Recordset = cmd.Execute()
End Sub

Open in new window


This is my screen print
screenprint
0
Veeam Disaster Recovery in Microsoft Azure

Veeam PN for Microsoft Azure is a FREE solution designed to simplify and automate the setup of a DR site in Microsoft Azure using lightweight software-defined networking. It reduces the complexity of VPN deployments and is designed for businesses of ALL sizes.

 
mbizupCommented:
Okay...

Its not clear how you are storing the data for the listbox, but I think the code behind the textbox (Exit Event perhaps) would be something along these lines:

Dim strSQL as string

' Update your table
strSQL = "UPDATE YourListBoxTable SET Hours = " & me.txtHoursReg & " WHERE Definition = 'Hours - Regular' AND PersonID = " & Me.PersonID
CurrentDB.execute strSQL, dbFailOnError + dbSeeChanges

'Re-load the listbox
LoadSID

Open in new window

0
 
lrbristerAuthor Commented:
mbizup
This has to stay client side.
There may be dozens of people updating hundreds of  records for the same customer at the same time.

On the client side is there no way of making provate recordset variable and updating the record for a particular row and then rebinding the listbox to THAT recordset?

In .Net this isn't an issue...I'd just cache everything and feed it back into the dataset/datatable.

But these folks are still in MS Access and I have to deal with this.
0
 
mbizupCommented:
Okay try this from the exit or lost focus event of  your text box:

dim rs as DAO.recordset
set rs = Me.lbvHoursSID.Recordset
rs.FindFirst "Definition = 'Hours - Regular'"
rs.Edit
rs!Hours = me.txtHoursReg
rs.update
Me.lbvHoursSID.Requery

Open in new window

0
 
lrbristerAuthor Commented:
mbizup
That didn;t work but after moving things around...I'm looping through (to see if I can)

The code is failing on the rst.Fields("Hours").Value = 30 line.

Screenprint of error message follows

Screenprint
0
 
Rey Obrero (Capricorn1)Commented:
lrbrister,
<This has to stay client side.>


if i am reading it correctly, you don't need to update the "TABLE" used as the rowsource of your listbox?

but, you need to see changes in the RowSource of your listbox,  is that correct?


if that is the case, you may need to use disconnected recordsets

see this links

http://support.microsoft.com/?kbid=281998

http://support.microsoft.com/kb/195082
0
 
lrbristerAuthor Commented:
Capricorn1,
 Sorry for the late get back.

Thanks
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

  • 4
  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now