Mysql
 sql >> Base de données >  >> RDS >> Mysql

Coincé dans la construction de la requête MySQL

Pour toutes les colonnes des lignes, vous pouvez utiliser une jointure interne sur la sous-sélection du prix d'enchère minimum

select m.id, m.item_id, m.user_id, m.bid_price
from my_table m 
inner join ( 
select item_id, min(id) min_id,  min(bid_price) min_price
from my_table 
where   item_id IN (1,2,3)
group by item_id 
) t on t.item_id = m.item_id 
   and t.min_price= m.bid_price
   and t.min_id = m.id

ou .. si vous avez un type de données flottant, vous pouvez utiliser un acst pour unsigned

  select m.id, m.item_id, m.user_id, cast(m.bid_price as UNSIGNED) 
  from my_table m 
  inner join ( 
  select item_id, min(id) min_id,  min(bid_price) min_price
  from my_table 
  where   item_id IN (1,2,3)
  group by item_id 
  ) t on t.item_id = m.item_id 
     and t.min_price= m.bid_price
     and t.min_id = m.id