[Webinar] Streamline your web hosting managementRegister Today

x
?
Solved

Using controls to create sql statement

Posted on 2006-10-22
11
Medium Priority
?
187 Views
Last Modified: 2016-08-29
Hi experts,

I want to create a text box that builds a sql statement as users add variation options to text boxes above.

I have text1 which is for surname, text 2 for first name and check 1 which is for life member.

I have a text box called sqlsrch.  This is defaulted to "select * from members order by surname"

When the user enters LIT into the surname box, i want the sql statement in sqlsrch box to update to be "select * from members where surname LIKE '%LIT%' order by surname"

And then when the life member check is ticket to make the same statement "select * from members where surname LIKE '%LIT%' and lifemem = 1 order by surname"

And so on.

I have seen this done in an application that I once used for work.  How do you make this happen? There has to be an easier way that to have several if tests to filter which option is being used?
0
Comment
Question by:andrewl77
  • 5
  • 3
  • 3
11 Comments
 
LVL 9

Expert Comment

by:Hypnochu
ID: 17784356

SQLString = "select * from members where surname LIKE '%" & Trim(text1.text) & "%' and lifemem = " & check1.value & " order by surname"

If there's nothing in text1, the query will return everyone.
Assuming that anyone who isn't a life member has lifemem = 0 in their record, rather than Null.
0
 

Author Comment

by:andrewl77
ID: 17785372
I don't think you understand what my question is.  If surname text field is blank it doesn't even mention it in the sql statement.  Once text is typed into the surname text field, it then references it into the statement. Same goes with the check box, no touch, no reference.

I am assuming on each control there will be a on change action but not sure how to add.
0
 
LVL 15

Expert Comment

by:JackOfPH
ID: 17786053
0
The new generation of project management tools

With monday.com’s project management tool, you can see what everyone on your team is working in a single glance. Its intuitive dashboards are customizable, so you can create systems that work for you.

 
LVL 15

Expert Comment

by:JackOfPH
ID: 17786062
Here is sample: Put two textbox in the form and 1 checkedbox.

'Paste this code in the form...

Private Sub Check1_Click()

If Check1.Value = 1 Then
    Text1.Text = "select * from members where surname LIKE '" & Text2.Text & "' and lifemem = 1 order by surname"
Else
    Text1.Text = "select * from members where surname LIKE '" & Text2.Text & "' order by surname"
End If
End Sub

Private Sub Text2_Change()
If Not Text2.Text = "" And Me.Check1.Value = True Then
Text1.Text = "select * from members where surname LIKE '" & Text2.Text & "' and lifemem = 1 order by surname"
End If
If Not Text2.Text = "" And Me.Check1.Value = False Then
Text1.Text = "select * from members where surname LIKE '" & Text2.Text & "' order by surname"
End If


Type the surname to the second check box (text2).
0
 
LVL 15

Expert Comment

by:JackOfPH
ID: 17786069
>>Type the surname to the second check box (text2).

Type the surname to the second text box instead (text2).

"Just human... prone to error hehehe... Silly of me..."

Jack :)
0
 
LVL 15

Expert Comment

by:JackOfPH
ID: 17786071
Did you get the IDEA?
0
 

Author Comment

by:andrewl77
ID: 17786256
Yeah i get the idea...i was hoping to avoid having to go down that path!!!!!
0
 
LVL 15

Expert Comment

by:JackOfPH
ID: 17786810
It seems you have too..
0
 
LVL 9

Accepted Solution

by:
Hypnochu earned 200 total points
ID: 17787513
How about

Sub UpdateSQL()
    Dim sSQL As String
    sSQL = "select * from members "
    sSQL = sSQL & "where "
    sSQL = sSQL & " lifemem = " & Check1.Value
    If Trim(Text1.Text) <> "" Then sSQL = sSQL & " and surname LIKE '%" & Trim(Text1.Text) & "%' "
    If Trim(Text2.Text) <> "" Then sSQL = sSQL & " and firstname LIKE '%" & Trim(Text2.Text) & "%' "
    sSQL = sSQL & " order by surname"
    sqlsrch.Text = sSQL
End Sub

Private Sub Form_Load()
    UpdateSQL
End Sub

Private Sub Text1_Change()
    UpdateSQL
End Sub

Private Sub Text2_Change()
    UpdateSQL
End Sub

Private Sub Check1_Click()
    UpdateSQL
End Sub

?
0
 
LVL 9

Expert Comment

by:Hypnochu
ID: 17787710
Modification - don't see a neater way to do this:

Sub UpdateSQL()
    Dim sSQL As String
    Dim bHasCheck As Boolean
    Dim bHasFirstname As Boolean
    Dim bHasSurname As Boolean
   
    bHasCheck = (Check1.Value = 1)
    bHasSurname = (Trim(Text1.Text) <> "")
    bHasFirstname = (Trim(Text2.Text) <> "")
   
    sSQL = "select * from members "
    If bHasSurname Or bHasFirstname Or bHasCheck Then sSQL = sSQL & "where "
    If bHasSurname Then sSQL = sSQL & " surname LIKE '%" & Trim(Text1.Text) & "%' "
    If bHasFirstname Then
        If bHasSurname Then sSQL = sSQL & " and "
        sSQL = sSQL & " firstname LIKE '%" & Trim(Text2.Text) & "%' "
    End If
    If bHasCheck Then
        If bHasSurname Or bHasFirstname Then sSQL = sSQL & " and "
        sSQL = sSQL & " lifemem = " & Check1.Value
    End If
    sSQL = sSQL & " order by surname"
    sqlsrch.Text = sSQL
End Sub
0
 

Author Comment

by:andrewl77
ID: 17794898
Thanks, Hypnochu

I slightly modified your technique as the check boxes annoyed me and excluded data and the wrong time.  However i used combo boxes and made it work the way i want!

Top Stuff!
0

Featured Post

The new generation of project management tools

With monday.com’s project management tool, you can see what everyone on your team is working in a single glance. Its intuitive dashboards are customizable, so you can create systems that work for you.

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…
You can of course define an array to hold data that is of a particular type like an array of Strings to hold customer names or an array of Doubles to hold customer sales, but what do you do if you want to coordinate that data? This article describes…
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…
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Suggested Courses

607 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