Garayed.com  

Go Back   Garayed.com > mySQL
FAQ Members List Calendar Search Today's Posts Mark Forums Read


Reply
 
LinkBack Thread Tools Search this Thread Display Modes
  #1 (permalink)  
Old 07-22-2007, 11:36 AM
Paul Lautman
 
Posts: n/a
Default COALESCE or LIMIT?

I need to solve a problem similar to the language one whereby if a
translation in the chosen languange does not exist, the default one should
be selected. My problem is actually picking a price specific to a certain
class if available or a default price otherwise.

So taking a table like:

CREATE TABLE `price_table` (
`class` varchar(1) NOT NULL,
`item` varchar(1) NOT NULL,
`price` int(11) NOT NULL,
PRIMARY KEY (`item`,`class`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;

INSERT INTO `price_table` (`class`, `item`, `price`) VALUES
('', 'A', 50),
('1', 'A', 60),
('', 'B', 30),
('', 'C', 20),
('2', 'C', 0);

to find the price of item A I could do:

SELECT
`price`
FROM `price_table`
WHERE `item` = '$item' AND (`class` = '$class' OR `class` = '')
ORDER BY `class` DESC
LIMIT 1

so if $item was 'A' $class was '1', I would get 60, otherwise I will get 50.

Or I could do

SELECT
COALESCE(`s`.`price`,`d`.`price`) `price`
FROM `price_table` `d`
LEFT JOIN `price_table` `s` ON `s`.`item` = `d`.`item` AND `s`.`class` =
'$class'
WHERE `d`.`item` = '$item' AND `d`.`class` = ''

My inclination is to go with the LEFT JOIN, but what do others think?


Digg this Post!Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!
Reply With Quote
Reply


Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

vB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On



All times are GMT. The time now is 09:12 PM.




LinkBacks Enabled by vBSEO 3.0.0 © 2007, Crawlability, Inc.