如何按 Laravel 查询生成器中的首字母计数?

How count by the first letters in Laravel Query Builder?

我想按第一个字母数...我有这个栏目

我想计算每个 OE 行和每个 GICS 行

我正在处理这个查询

$data4 = DB::table('incidencias')
   ->select(DB::raw('grupo_asig as grupo_asig'), DB::raw('count(*) as number'))
   ->whereNotIn('grupo_asig', [''])
   ->groupBy('grupo_asig')
   ->orderBy('number', 'desc')
   ->get();

您应该尝试使用 [LIKE][1] 函数并将其添加到您的查询中:

->where('grupo_asig', 'like', 'OE%')
->where('grupo_asig', 'like', 'GICS%')

编辑:

我尝试了很多,找到了这个解决方案并提出了 SQL fiddle:http://sqlfiddle.com/#!9/06a39b/8

对你有帮助吗?

您可以使用 Collections。无需对您的查询进行太多更改。

$data4 = DB::table('incidencias')
   ->select('grupo_asig')
   ->selectRaw('count(*) as number'))
   ->whereNotIn('grupo_asig', [''])
   ->groupBy('grupo_asig')
//   ->orderBy('number', 'desc') Unless you use this array somewhere, it's not needed.
   ->get(); 
use Illuminate\Support\Str;
...

// php >= 7.4.0
$oe_count = $data4->filter(fn($data) => Str::startsWith($data->grupo, 'OE '))->count();
$gigs_count = $data4->filter(fn($data) => Str::startsWith($data->grupo, 'GIGS '))->count();
// php < 7.4.0
$oe_count = $data4->filter(function ($data) {
    return Str::startsWith($data->grupo, 'OE ');
})->count();
$gigs_count = $data4->filter(function ($data) {
    return Str::startsWith($data->grupo, 'GIGS ');
})->count();

从 Laravel 6 开始,您还可以在对 return LazyCollection 的查询中使用 cursor() 而不是 get()。这种情况下速度更快。

我建议为此使用查询:

参考this answer


SELECT
    LEFT(grupo_asig, 1) AS first_letter,
    COUNT(*) AS total
FROM incidencias
GROUP BY first_letter

使用CASE WHEN并计算像OEASIG

这样的字段
$data4 = DB::table('incidencias')
           ->select(DB::raw("(CASE WHEN grupo_asig LIKE 'OE%' THEN 'OE'
                                   WHEN grupo_asig LIKE 'GICS%' THEN 'GICS'
                              END) AS grupo_asig_type"), 
                    DB::raw('COUNT(*) as number'))
           ->whereNotIn('grupo_asig', [''])
           ->groupBy('grupo_asig_type')
           ->orderBy('number', 'desc')
           ->get();