SQL OR operator question

On my real estate search page form I have a distinct query that pulls in all the property types, "type", and it's quite a few in my dropdown select!  I'd like to group some of the property types together to make the select dropdown more user friendly. Such as I'd like to group the type "condo" with "townhouse" and "zero lot line" in my form select dropdown, instead of having :

Condo
Townhouse
Zero Lot Line

I want:

Condo / Townhouse / Zero Lot Line




My form submits to results page query:

<cfif StructKeyExists(form,"Type") and len(trim(form.Type))>
 AND Type = (
 <cfqueryparam value="#form.Type#" cfsqltype="cf_sql_varchar" list="true">
     )
</cfif>


So on my search form select I tried to hard code the property type like this:

 <option value="Townhouse" OR Type="Condominium" OR Type="Zero Lot Line">Condo / Townhouse / Zero Lot Line</option>



It does not throw an error, but it only queries the first type "Townhouse" and not condominium or zero lot line.

Can someone show me a better way to code this?

Thanks!
Bang-O-MaticAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

_agx_Commented:
Make the option value a list. Use a character unlikely to appear in the data, maybe a "|" symbol:

<option value="Townhouse|Condominium|Zero Lot Line">....

Then change your query to that delimiter with an IN clause:

<cfif StructKeyExists(form,"Type") and listLen(trim(form.Type), "|")>
 AND Type IN
        (
             <cfqueryparam value="#form.Type#"
                   cfsqltype="cf_sql_varchar"
                   list="true"
                   separator="|">
     )
</cfif>
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
Bang-O-MaticAuthor Commented:
Hi _agx_ , Works perfect! Thank you so much!, again, LOL
0
_agx_Commented:
... OR if you have a separate PropertyType table, you could add a "category" column.

Category
1  |  Category A
2  |  Category B

PropertyType    |  CategoryID
Condo              |  1  <=== Category  A
Townhouse       |  1  <=== Category  A
Zero Lot Line   |  1  <=== Category  A
Duplex             |  2  <=== Category  B
Ranch              |  ......

Then filter on the categoryID value instead. Not tested, but something like:

<select name="categoryID" ...>
  <option value="#CategoryID#">Condo / Townhouse / Zero Lot Line</option>
 .....

<cfif StructKeyExists(form,"Type") and listLen(trim(form.Type), "|")>
 AND CategoryID =  <cfqueryparam value="#form.CategoryID#"
                   cfsqltype="cf_sql_integer" >
</cfif>
0
Bang-O-MaticAuthor Commented:
Quick, concise and perfect! Thank you _agx_
0
_agx_Commented:
Welcome :) Any time
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Query Syntax

From novice to tech pro — start learning today.