ホームページ > データベース > mysql チュートリアル > タイムスタンプが異なる日ごとにLaravel Eloquentの結果をグループ化するにはどうすればよいですか?

タイムスタンプが異なる日ごとにLaravel Eloquentの結果をグループ化するにはどうすればよいですか?

DDD
リリース: 2024-10-27 07:46:02
オリジナル
520 人が閲覧しました

How do I group Laravel Eloquent results by days when timestamps vary?

Laravel の雄弁な結果を日ごとにグループ化する

Laravel では、データベースにクエリを実行するときに、タイムスタンプではなく日ごとに結果をグループ化する必要が生じる場合があります。この特定のシナリオに対処するための詳細な質問と回答を次に示します。

質問:

page_views という名前のテーブルがあり、タイムスタンプ、ユーザー IP アドレス、ページ ID とともにページ訪問の記録が保存されています。 。 groupBy メソッドを使用しているにもかかわらず、タイムスタンプ内の秒単位の違いにより、クエリではデータが日ごとに正しくグループ化されません。

1 日あたりのビューに基づいて結果を取得したいと考えています。

  date          views
  ====          =====
10-11-2013       15
10-12 2013       45
  ...            ...
ログイン後にコピー

誰か洞察や解決策を提供できますか?

回答:

結果を日ごとに効果的にグループ化するには、DateTime から日付部分を抽出する MySQL の DATE() 関数を活用することを提案しています。 value:

DB::table('page_views')
      ->select(DB::raw('DATE(created_at) as date'), DB::raw('count(*) as views'))
      ->groupBy('date')
      ->get();
ログイン後にコピー

ただし、この生のクエリ アプローチは、Eloquent のクエリ ビルダー構文から逸脱しています。より Eloquent 指向のソリューションの場合、答えは次のようになります。

$visitorTraffic = PageView::where('created_at', '>=', \Carbon\Carbon::now->subMonth())
                            ->groupBy('date')
                            ->orderBy('date', 'DESC')
                            ->get(array(
                                DB::raw('Date(created_at) as date'),
                                DB::raw('COUNT(*) as "views"')
                            ));
ログイン後にコピー

このクエリは、比較のために最初の where 句で炭素日付を利用し、get メソッド内で適切な DB raw 式を適用して両方の日付を取得します。と閲覧数。

以上がタイムスタンプが異なる日ごとにLaravel Eloquentの結果をグループ化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート