Solved

500pts - I have two SQL queries that I am trying to combine into one. Don't quite know how to go about it.

Posted on 2006-07-13
3
176 Views
Last Modified: 2010-05-18
Greetings,

I have two SQL queries that I use to generate shipping labels. One query extracts Address that are for U.S Military locations (APO's) and one for International (outside the U.S.)addresses.

International and APO's are all handled the same way by the US Post Office so I am trying to combine these queries so that they will produce a record set that contains all APO's and all International address.

------code for APO select---------
SQL = "Select * From Addresses where LabelPrinted = " & Chr(34) & "no" & Chr(34)
       
 SQL = SQL$ & " AND (State LIKE " & Chr(34) & "AP" & Chr(34) & " OR State LIKE " & Chr(34) & "AE" & Chr(34) & " OR State LIKE " & Chr(34) & "AA" & Chr(34) & " )"
   
   -----end APO select---------

This produces a record set for all Military APO's

------code for International (outside the US) select---------
SQL = "Select * From Addresses where LabelPrinted = " & Chr(34) & "no" & Chr(34)

SQL = SQL$ & " AND (Country NOT LIKE " & Chr(34) & "U.S.A." & Chr(34) & " AND Country NOT LIKE " & Chr(34) & "USA" & Chr(34) & " AND Country NOT LIKE " & Chr(34) & "United States" & Chr(34) & " AND Country <> " & Chr(34) & "" & Chr(34) & ")"

  -----end International select---------

This produces a record set for all International (outside the US) addresses.

I now want to combine them into a single statement but I am having a problem. Th equery that I generate is as follows:

------combined query--------
SQL = "Select * From Addresses where LabelPrinted = " & Chr(34) & "no" & Chr(34)

SQL = SQL$ & " AND (Country NOT LIKE " & Chr(34) & "U.S.A." & Chr(34) & " AND Country NOT LIKE " & Chr(34) & "USA" & Chr(34) & " AND Country NOT LIKE " & Chr(34) & "United States" & Chr(34) & " AND Country <> " & Chr(34) & "" & Chr(34) & ")"

SQL = SQL$ & " AND (State LIKE " & Chr(34) & "AP" & Chr(34) & " OR State LIKE " & Chr(34) & "AE" & Chr(34) & " OR State LIKE " & Chr(34) & "AA" & Chr(34) & " )"
-----end combine---------

This doesn't work. I know that it is failing because of the 'Evauation' against 'Country'. The country of origin for all APO's is the US and since the evaluation is 'ANDED', APO's are thrown out because of the 'Country' test, AND the other countries are thrown out because of the APO test. Therefore the results of this query is an empty record set.

So what do I need to do to create a query that wil result in a combined record set?

Any help would be appreciated.

rrbecker
0
Comment
Question by:rrbecker
  • 2
3 Comments
 
LVL 26

Accepted Solution

by:
EDDYKT earned 500 total points
ID: 17105246
how about use union all


ie

select ...  union all select ...
0
 
LVL 2

Author Comment

by:rrbecker
ID: 17105256
Hi EDDYKT,

I don't know. I've never tried that. I'll give it a try and let you know

rrbecker
0
 
LVL 2

Author Comment

by:rrbecker
ID: 17105298
Hi EDDYKT,

Looks like it will work. Is there a cleaner way?

rrbecker
0

Featured Post

Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
add text to end of existing text in file 16 70
VB 6.0 printer how to align 6 62
MS Date Picker 64 bit 32 bit issue 12 53
How to make an ADE file by code? 11 83
I’ve seen a number of people looking for examples of how to access web services from VB6.  I’ve been using a test harness I built in VB6 (using many resources I found online) that I use for small projects to work out how to communicate with web serv…
This article describes some techniques which will make your VBA or Visual Basic Classic code easier to understand and maintain, whether by you, your replacement, or another Experts-Exchange expert.
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…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…

776 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