sql >> Databáze >  >> RDS >> Mysql

Laravel Eloquent skupina podle nejnovějšího záznamu

Chcete-li získat nejnovější záznam na zákazníka pro každé město na základě created_at můžete použít vlastní připojení

DB::table('yourTable as t')
  ->select('t.*')
  ->leftJoin('yourTable as t1', function ($join) {
        $join->on('t.Customer','=','t1.Customer')
             ->where('t.City', '=', 't1.City')
             ->whereRaw(DB::raw('t.created_at < t1.created_at'));
   })
  ->whereNull('t1.id')
  ->get();

V prostém SQL by to bylo něco jako

select t.*
from yourTable t
left join yourTable t1
on t.Customer = t1.Customer
and t.City = t1.City
and t.created_at < t1.created_at
where t1.id is null

Ukázka

Jiný přístup s vlastním vnitřním spojením by byl

select t.*
from yourTable t
join (
    select  Customer,City,max(ID) ID
    from yourTable
    group by Customer,City
) t1
on t.Customer = t1.Customer
and t.City = t1.City
and t.ID = t1.ID

Ukázka




  1. java.sql.SQLException:- ORA-01000:překročen maximální počet otevřených kurzorů

  2. Automatická aktualizace zobrazení v MySql

  3. Jak uložit znak Emoji v databázi MySQL

  4. Jak získat informace o typu definovaném uživatelem?