Home  |  Linux  | Mysql  | PHP  | XML
From:Chris Date:Mon Feb  8 02:13:33 2010
Subject:Re: Cross reference query help
Ron Piggott wrote:
> The following is a query I am working on today.  I need help tweaking on it.
> 
> What I am trying to get for results from the query are where there are
> rows in either table, not all 3 tables linked together.
> 
> In other words I am trying to INNER JOIN these two pairs of tables for
> possible results:
> 
> `store_product_profile` and `paypal_cart_info`
> 
> OR
> 
> `store_product_profile` and `mail_order_cart`
> 
> SELECT `store_product_profile`.`product_name`
> FROM (
> `store_product_profile`
> INNER JOIN `paypal_cart_info` ON `store_product_profile`.`reference` =
> `paypal_cart_info`.`itemnumber`
> )
> INNER JOIN `mail_order_cart` ON `store_product_profile`.`reference` =
> `mail_order_cart`.`store_product_profile_reference`
> WHERE `store_product_profile`.`discontinued` =0
> AND `store_product_profile`.`reference` =7
> 
> Finally I need help with the GROUP BY syntax also.  I only want the name
> of the product once, not if it was in several previous purchases.
> 
> Any help is appreciated.

So a product is either in the paypal_cart_info table or it's in the 
mail_order_cart table ?

Though maybe this is a bad example - it's looking for reference=7 - you 
can check for that in your other tables since it seems to be a foreign 
key of some sort I'm guessing.

You could use a union (or union all is probably better in this case) to 
bring them together.


select itemnumber
from paypal_cart_info
where itemnumber=7
union all
select store_product_profile_reference
from mail_order_cart
where store_product_profile_reference=7

put that into your other query and add your group by:

select product_name
from store_product_profile
where
   reference in
   (
     select itemnumber
     from paypal_cart_info
     where itemnumber=7
     union all
     select store_product_profile_reference
     from mail_order_cart
     where store_product_profile_reference=7
   )
   and
   discontinued=0
group by
   product_name;


If you put the check for '7' in the paypal and mail_order_cart tables 
it'll be faster than putting it in the bigger query.

The smaller subquery will return less results (I'm guessing 0,1, or 2 
results) and therefore the discontinued check will be quicker and so 
will the group by.

If you don't put the check for '7' in the subquery, then mysql will have 
to go through *all* entries in paypal_cart_info and mail_order_cart 
(which may or may not be big tables), then make sure there is a 
reference entry in product_profile (which could be a pretty big table) 
and finally at the end of all that, check if reference '7' is in that 
list and it's not discontinued (then the group by etc).

So in general, the further down the query chain you can put your where 
clauses to reduce the number of rows returned, the better.

-- 
Postgresql & php tutorials
http://www.designmagick.com/

Navigate in group php.db at sever news.php.net
Previous Next


Your recent visits
mailto:beginners-uc.1265554412.pbjbnmdgcoehhijoegcf-anilputhiyath
Sybase IQ 15 - caught signal 11, program abort
Re: [PHP] php selecting multiple stylesheets
Re: sequential value check
Re: [PHP-DB] Storing images


  
© No Copyright
You are free to use Anything
Site Maintained by Zareef Ahmed
Powered By PHP Consultants