sql >> Database >  >> RDS >> Mysql

Laravel welsprekend krijgt de meest voorkomende waarde in een databasekolom

Welsprekend:

App\Animal::select('name')
    ->groupBy('name')
    ->orderByRaw('COUNT(*) DESC')
    ->limit(1)
    ->get();

Uitgang:

=> Illuminate\Database\Eloquent\Collection {#711
     all: [
       App\Animal {#725
         name: "cat",
       },
     ],
   }

Hetzelfde met Query Builder:

DB::table('animals')
    ->select('name')
    ->groupBy('name')
    ->orderByRaw('COUNT(*) DESC')
    ->limit(1)
    ->get();

Uitgang:

=> Illuminate\Support\Collection {#734
     all: [
       {#738
         +"name": "cat",
       },
     ],
   }

Natuurlijk is er

App\Animal::select('name')
    ->selectRaw('COUNT(*) AS count')
    ->groupBy('name')
    ->orderByDesc('count')
    ->limit(1)
    ->get();
=> Illuminate\Database\Eloquent\Collection {#711
     all: [
       App\Animal {#725
         name: "cat",
         count: 123
       },
     ],
   }



  1. MySQL INSERT ....OP DUPLICATE UPDATE - Voegt een toe aan de autoincrement

  2. MySQL versus SQL Server Express

  3. Resultaat van dynamische SQL in een variabele voor sql-server krijgen

  4. Hoe programmeer je een MySQL-trigger om een ​​rij in een andere tabel in te voegen?