Solved

data-bound grid with selectable column

Posted on 2003-11-30
8
678 Views
Last Modified: 2013-12-25
Hey
I'm currently working on an application (VB6) that uses an Access database for its data. I have tried and tried to be able to have a selecteble column in a Flex Grid and Hierarchial Flex Grid, but have not been successful.

The basic idea is that i can select the first column of a row from the flexgrid. and the flexgrid will put a tick or leave it unticked (True/False type thing), furthermore i need it to be able to change the underlying Access database field (which is a true/false field), either by code or not.
From the selected (ticked) rows i call some reports from the database and display them to the user (this part fine, can do this)

So does anyone know of a way of doing this? or is there a different control that can handle this.
btw i've tried CoolFlex, which works to an extent however would rather a data-bound version.

Thanks in advance for your assistance.
Regards
David
0
Comment
Question by:gumbyss
  • 6
  • 2
8 Comments
 
LVL 8

Expert Comment

by:MYLim
ID: 9848196
you got to use ListView control...
0
 
LVL 8

Expert Comment

by:MYLim
ID: 9848218
inside "mirosoft common control 6.0" then code will like below:
formload()
me.ListView1.Checkboxes=True
0
 
LVL 8

Accepted Solution

by:
MYLim earned 500 total points
ID: 9848273
'Below are code to load data,Modify to suite your code.Pls wait for "update" code...
'Remember to reference microsoft ActiveX data Object 2.7 library...

Private Sub Form_Load()
    Listld.Checkboxes = True
    Call LoadChk
End Sub

Private Sub LoadChk()
On Error GoTo ErrFound
Dim G, H As Integer
Dim item As ListItem
Dim CnnList As ADODB.Connection
Dim RsList As ADODB.Recordset
Dim StrSql, StrCnn, SQL As String
   
    StrCnn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\ZDbGridTest\test1.mdb;User Id=admin;Password=;"

    StrSql = "Select * from yourTable"
   
       Set CnnList = New ADODB.Connection
       CnnList.CursorLocation = adUseClient
       CnnList.Open StrCnn

        Set RsList = New ADODB.Recordset
        RsList.CursorType = adOpenStatic
        RsList.CursorLocation = adUseClient
        RsList.LockType = adLockOptimistic
        RsList.ActiveConnection = CnnList
        RsList.Open StrSql

Listld.View = lvwReport
Listld.ListItems.Clear
Me.Listld.ColumnHeaders.Clear

For H = 0 To RsList.Fields.Count - 1
    Listld.ColumnHeaders.Add , , RsList.Fields(H).Name
    Debug.Print RsList.Fields(H).Name
Next

While Not RsList.EOF
Set item = Me.Listld.ListItems.Add(, , RsList.Fields(0))
    For G = 1 To RsList.Fields.Count - 1
    item.SubItems(G) = RsList.Fields(G) & " "
    Next
    RsList.MoveNext
Wend

RsList.Close
Set RsList = Nothing

CnnList.Close
Set CnnList = Nothing

Exit Sub
ErrFound:
MsgBox "Error Source : " & Err.Source & "; Error description : " & Err.Description, vbCritical, Err.Number
End Sub



0
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!

 
LVL 1

Author Comment

by:gumbyss
ID: 9848313
Have created a 'test' project and so far so good, look to be the way i want it.  
So thanks for that

As requested i will wait for the update code....

Really big thanks so far :D
0
 
LVL 8

Expert Comment

by:MYLim
ID: 9848761
'sorry,my wingate server have little problem...
'Please move 2 line of code to form general section:
'Dim CnnList As ADODB.Connection
'Dim RsList As ADODB.Recordset
'----------------------------------------------------------
'Please move 4 line of code to form_unload()
'RsList.Close
'Set RsList = Nothing
'CnnList.Close
'Set CnnList = Nothing

Private Sub Command1_Click()
Dim i As Long
i = 0

'Debug.Print "Index : " & Listld.ListItems.Count
RsList.MoveFirst
For i = 1 To Listld.ListItems.Count
'Debug.Print "----------------------------------------"
    Listld.ListItems.item(i).Selected = True
   
    If Listld.ListItems.item(i).Checked = True Then
        'Debug.Print "Checked = TRUE"
        RsList.Fields("student").Value = 1
    Else
        'Debug.Print "NOT CHECKED"
        RsList.Fields("student").Value = 0
    End If
    RsList.MoveNext
Next i

End Sub
0
 
LVL 8

Expert Comment

by:MYLim
ID: 9848797
Lastly,Please post your result...
0
 
LVL 1

Author Comment

by:gumbyss
ID: 9854597
Again Thanks for all you help...i've been able to adapt it to suit what i required. was a vary detailed answer.  So A big thanks

You should have already gotten the 500 points :D
0
 
LVL 8

Expert Comment

by:MYLim
ID: 9854639
thank's
q(^ _ ^)p
regards:
Mike
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

Introduction While answering a recent question about filtering a custom class collection, I realized that this could be accomplished with very little code by using the ScriptControl (SC) library.  This article will introduce you to the SC library a…
When designing a form there are several BorderStyles to choose from, all of which can be classified as either 'Fixed' or 'Sizable' and I'd guess that 'Fixed Single' or one of the other fixed types is the most popular choice. I assume it's the most p…
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

679 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