?
Solved

Help with a query

Posted on 2002-04-05
6
Medium Priority
?
172 Views
Last Modified: 2006-11-17
I am building an e-commerce site for motor accesories.  The idea is that the users selects their product and then their car type and model.  I would like to show only products that apply to that model.

My database is structured like:

PRODUCTS TABLE
ProductID (Autonumber)
ProductName (Text)
ProductModels (Text)

CAR MAKES TABLE (eg Ford)
MakeID

CAR MODELS TABLE (eg Escort)
ModelID

So in English I would like to show:

SELECT ALL
FROM PRODUCTS TABLE
WHERE ModelID NOT IN ProductModels

Is this possible?

Thanks

Robert
0
Comment
Question by:Orroland
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
6 Comments
 
LVL 9

Expert Comment

by:ornicar
ID: 6920808
The SQL syntax for this query is:

SELECT * FROM PRODUCTS
WHERE PRODUCTID NOT IN
(SELECT MODELID FROM PRODUCTMODELS)

0
 
LVL 54

Expert Comment

by:nico5038
ID: 6920824
Hi ornicar,

I guess you ment:
SELECT * FROM PRODUCTS
WHERE PRODUCTID NOT IN
(SELECT PRODUCTMODELS FROM PRODUCT);

But I get the impression that Richard stores multiple models in one PRODUCTMODELS field...
This would imply that there's a change of database design necessary or a "like *modelid*" construction...

Whats the content of the PRODUCTMODELS field Richard?

Nic;o)
0
 

Author Comment

by:Orroland
ID: 6920831
It is a text field with the modelID like 1,2,3,4.  I use check boxes to select the models which apply to the product.
0
Comprehensive Backup Solutions for Microsoft

Acronis protects the complete Microsoft technology stack: Windows Server, Windows PC, laptop and Surface data; Microsoft business applications; Microsoft Hyper-V; Azure VMs; Microsoft Windows Server 2016; Microsoft Exchange 2016 and SQL Server 2016.

 

Author Comment

by:Orroland
ID: 6920883
This is giving a Data type mismatch in criteria expression error???

...WHERE modelsubcats.modelsubcatID NOT IN (SELECT productdetails.productdetailmodels FROM productdetails)
0
 
LVL 54

Accepted Solution

by:
nico5038 earned 200 total points
ID: 6920909
That's because you store the numbers of multiple models, thus the field becomes.... text ;-)

The "general" solution for this is to create a "relation table" like:
tblProductModel with the fields:
ProductID
ModelID
Both making the unique key of the table.

BTW I would also change the CarsModels table into:
CAR MODELS TABLE (eg Escort)
MakeID
ModelID

Thus the relation between Make and Model becomes clear.

Havin created the relation table you can use your checkboxes to insert for each checked model the relation row.

Now the query is simply linking tblProductModel to the Products to show the productname.

Clear ?

Nic;o)
0
 

Author Comment

by:Orroland
ID: 6920969
Thanks for the help, this is a great solution.

Robert
0

Featured Post

Prepare for your VMware VCP6-DCV exam.

Josh Coen and Jason Langer have prepared the latest edition of VCP study guide. Both authors have been working in the IT field for more than a decade, and both hold VMware certifications. This 163-page guide covers all 10 of the exam blueprint sections.

Question has a verified solution.

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

This article describes two methods for creating a combo box that can be used to add new items to the row source -- one for simple lookup tables, and one for a more complex row source where the new item needs data for several fields.
The Windows Phone Theme Colours is a tight, powerful, and well balanced palette. This tiny Access application makes it a snap to select and pick a value. And it doubles as an intro to implementing WithEvents, one of Access' hidden gems.
With Microsoft Access, learn how to start a database in different ways and produce different start-up actions allowing you to use a single database to perform multiple tasks. Specify a start-up form through options: Specify an Autoexec macro: Us…
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…
Suggested Courses

777 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