Jump to content

Recommended Posts

Hi

 

I'm trying to do a simple subquery.

 

I have the following tables:

 

Orders = Purchases made

ordercart = list of products that belong to each purchase

Categories = product list

Designers = designer that have created that product

 

ordercart.product = categories.catid

orders.order_number = ordercart.id

categories.designerid = designers.designerid

 

 

I need all the order numbers that have products that belong to a specific designer so I can calculate commissions of sale for a given day. If I run these 2 queries by their own, they work ok, if I run them as a subquery, it gives me the following error.

 

What's wrong with the syntax??

 

SQL-query: Documentation

 

 

SELECT DISTINCT order_number

FROM orders, ordercart

WHERE orders.confirmed =1

AND orders.order_number = ordercart.id

AND DATE_FORMAT( thedate, '%d' ) =03

AND DATE_FORMAT( thedate, '%m' ) =04

AND DATE_FORMAT( thedate, '%Y' ) =2008

AND product

IN (

SELECT catid

FROM categories

WHERE designerid =9

)

LIMIT 0 , 30

 

MySQL said: Documentation

#1064 - You have an error in your SQL syntax.  Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SELECT catid FROM categories WHERE designerid = 9) LIMIT 0, 30'

Link to comment
https://forums.phpfreaks.com/topic/99359-solved-subuery-problem/
Share on other sites

all the values are numbers, no strings here.

 

What is strange is that if I do the following query it works:

 

SELECT DISTINCT order_number

FROM orders, ordercart

WHERE orders.confirmed =1

AND orders.order_number = ordercart.id

AND DATE_FORMAT( thedate, '%d' ) =03

AND DATE_FORMAT( thedate, '%m' ) =04

AND DATE_FORMAT( thedate, '%Y' ) =2008

 

without the subquery....

 

and even the inner part of the subquery works as a single query, so there are no mistakes in column or table names...

 

 

 

 

Perform the following query to be sure what version you are connecting to:

SELECT @@version;

 

Also, I suspect you should drop the DISTINCT as it's bad practise, and instead replace it with the correct JOIN and GROUP clause.

If you explain in plain text english what information you want out, a sample output, a sample input, and your schema i'm sure we can clarify how you can better structure this query and your database layout.

in this version, the syntax is different?

It's not different as much as it is unsupported. Try this (untested):

 

SELECT DISTINCT order_number
FROM orders 
INNER JOIN ordercart ON orders.order_number = ordercart.id
INNER JOIN categories ON orders.product = categories.catid
WHERE orders.confirmed =1 AND thedate = '2008-04-03' AND categories.designerid =9

I'm just guessing at tables here.

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.