I have a custom product attribute with actually three possible values: "Frühjahr / Sommer", "Herbst / Winter", "" (empty).
I want to sort a collection of products by this value in a predefined order, for example, "Frühjahr / Sommer", "Herbst / Winter", "OR" Herbst / Winter "," Frühjahr / Sommer ","
It alternates. Empty values should always be at the end, but perhaps there are more values, so it should be fixed in a predefined order.
I need to execute the following MySQL FIELD ORDER (saison, "Frühjahr / Sommer", "Herbst / Winter", "")
The problem is that I do not know how to execute this command in Magento. I know the "-> setOrder" method, but I need to fix a fixed order instead of using DESC or ASC.
I am looking a lot in stackoverflow and google, but there is no answer yet.
I hope you help me.
thanks
[edit in response to magalter's answer]
Unfortunately, it does not work, I tried this before:
$this->_collection->getSelect()->order(new Zend_Db_Expr("FIELD(season, 'Frühjahr/Sommer','Herbst/Winter','')"));
Result: "An error occurred while processing your request.
$this->_collection->getSelect();
Return:
SELECT `e`.*, `cat_index`.`position` AS `cat_index_position`, `price_index`.`price`, `price_index`.`tax_class_id`, `price_index`.`final_price`, IF(price_index.tier_price IS NOT NULL, LEAST(price_index.min_price, price_index.tier_price), price_index.min_price) AS `minimal_price`, `price_index`.`min_price`, `price_index`.`max_price`, `price_index`.`tier_price` FROM `catalog_product_entity` AS `e` INNER JOIN `catalog_category_product_index` AS `cat_index` ON cat_index.product_id=e.entity_id AND cat_index.store_id=1 AND cat_index.visibility IN(2, 4) AND cat_index.category_id='124' INNER JOIN `catalog_product_index_price` AS `price_index` ON price_index.entity_id = e.entity_id AND price_index.website_id = '1' AND price_index.customer_group_id = 0 ORDER BY FIELD(season, 'Frühjahr/Sommer','Herbst/Winter','')
I executed this sql statement in phpMyAdmin and received the following error message "Unknown column" in the order order section
If I order a "season" DESC
$this->_collection->setOrder('season', 'DESC');
it works ... and will generate the following sql statement
SELECT `e`.*, `cat_index`.`position` AS `cat_index_position`, `price_index`.`price`, `price_index`.`tax_class_id`, `price_index`.`final_price`, IF(price_index.tier_price IS NOT NULL, LEAST(price_index.min_price, price_index.tier_price), price_index.min_price) AS `minimal_price`, `price_index`.`min_price`, `price_index`.`max_price`, `price_index`.`tier_price`, IF(season_option_value_t2.value_id IS NULL, season_option_value_t1.value, season_option_value_t2.value) AS `season` FROM `catalog_product_entity` AS `e` INNER JOIN `catalog_category_product_index` AS `cat_index` ON cat_index.product_id=e.entity_id AND cat_index.store_id=1 AND cat_index.visibility IN(2, 4) AND cat_index.category_id='124' INNER JOIN `catalog_product_index_price` AS `price_index` ON price_index.entity_id = e.entity_id AND price_index.website_id = '1' AND price_index.customer_group_id = 0 LEFT JOIN `catalog_product_entity_int` AS `season_t1` ON e.entity_id=season_t1.entity_id AND season_t1.attribute_id='180' AND season_t1.store_id=0 LEFT JOIN `catalog_product_entity_int` AS `season_t2` ON e.entity_id=season_t2.entity_id AND season_t2.attribute_id='180' AND season_t2.store_id='1' LEFT JOIN `eav_attribute_option_value` AS `season_option_value_t1` ON season_option_value_t1.option_id=IF(season_t2.value_id > 0, season_t2.value, season_t1.value) AND season_option_value_t1.store_id=0 LEFT JOIN `eav_attribute_option_value` AS `season_option_value_t2` ON season_option_value_t2.option_id=IF(season_t2.value_id > 0, season_t2.value, season_t1.value) AND season_option_value_t2.store_id=1 ORDER BY `season` DESC
But this DESC order is not in the predefined order as I want it, so I cannot use it.
What I need is the SQL expression above with
ORDER BY FIELD(season, 'Frühjahr/Sommer','Herbst/Winter','')
instead
ORDER BY `season` DESC
Another idea ???