MySQL を使用してヒストグラム チャートを作成する – チュートリアル
MySQL でヒストグラム チャートを構築するための統計クエリを作成するには、COUNT() 関数を GROUP BY とともに使用して、グループ化制約によって作成された指定範囲またはカテゴリ内の値の出現をカウントします。
特に時系列データの場合、過去 30 日間の毎日の間隔で登録されたユーザーの数を監視するなど、ヒストグラムの使用例が数多くあります。これらのクエリを管理バックエンドで使用して、いくつかの重要な KPI を監視します。
残念ながら、SQL データベースはヒストグラムを表すためのネイティブ サポートを持っていませんでしたが、ヒストグラムはあらゆる種類のメトリクスを追跡するために最もよく使用されるグラフの 1 つです。
この記事では、この目的でクエリを作成し、いくつかの制限を克服する方法を説明します。 sales という名前のテーブルがあり、各セールの日付と時刻を含む sale_date という名前の列があるとします。月ごとの売上の分布を示すヒストグラム グラフを作成したいと考えています。
SELECT DATE_FORMAT(sale_date, '%Y-%m') AS sales_month, COUNT(*) AS count FROM sales GROUP BY DATE_FORMAT(sale_date, '%Y-%m');
このクエリ:
- DATE_FORMAT(sale_date, '%Y-%m') は、sale_date 列を年月形式にフォーマットします (例: 2024 年 1 月の場合は「2024-01」)。
- COUNT(*) は、各月内の販売件数をカウントします。
- FROM sales は、データを取得するテーブルを指定します。
- GROUP BY DATE_FORMAT(sale_date, '%Y-%m') は、書式設定された販売日に基づいて販売データを月次間隔にグループ化します。
このクエリにより、月ごとの間隔内の売上発生数が得られ、ヒストグラム グラフを作成して、経時的な売上の分布を視覚化できます。
ヒストグラム クエリのギャップを埋める方法
このクエリを実行すると、おそらく結果セットに欠落している月がいくつか表示されるでしょう。おそらく、特定の月には売上がないため、GROUP BY 関数はこれらの間隔のデータを生成できません。
これらのギャップをデフォルトのゼロ値で埋めるようにクエリを調整するにはどうすればよいでしょうか?そうしないと、ヒストグラムは不完全なままになります。
結果セットのギャップを埋めて、特定の月に売上がない場合でもすべての月が表示されるようにするには、再帰共通テーブル式 (CTE) を使用して、選択したカレンダー間隔の月を動的に生成できます。
目的の時間範囲をカバーする一連の日付を生成します。次に、この一連の日付と販売データを左結合して、すべての月を結果セットに含めることができます。
WITH RECURSIVE DateRange AS ( SELECT DATE_FORMAT(DATE_SUB(DATE_FORMAT(NOW(), '%Y-%m-01'), INTERVAL 11 MONTH), '%Y-%m-01') AS min_date, DATE_FORMAT(NOW(), '%Y-%m-01') AS max_date UNION ALL SELECT DATE_FORMAT(DATE_ADD(min_date, INTERVAL 1 MONTH), '%Y-%m-01'), max_date FROM DateRange WHERE DATE_ADD(min_date, INTERVAL 1 MONTH) <= max_date ) SELECT DATE_FORMAT(DateRange.min_date, '%Y-%m') AS sales_month, COUNT(sales.sale_date) AS count FROM DateRange LEFT JOIN sales ON DATE_FORMAT(DateRange.min_date, '%Y-%m') = DATE_FORMAT(sales.sale_date, '%Y-%m') GROUP BY sales_month ORDER BY sales_month;
DateRange CTE (共通テーブル式) は、販売テーブルの最小販売日と最大販売日の間の時間範囲をカバーする一連の月を再帰的に生成します。
このクエリは、販売テーブル内の最小販売日と最大販売日に基づいて、選択したカレンダー間隔の月を動的に生成し、すべての月が結果セットに表示されるようにします。
隙間をコードで埋める
SQL ソリューションは開発者にとって少し快適ではない可能性があり、また、より多くのカスタマイズが必要になるため、コードベースのソリューションが好まれる可能性があります。
この場合、次の 3 つの簡単な手順で同じ結果を達成できます。
- 興味のある時間間隔で配列を作成します。
- GROUP BY クエリから結果を取得します。
- それらを結合します。
Laravel と Carbon ライブラリを使用したコード スニペットは次のとおりです。
$dates = []; // Create the array with the time interval of your interests for( $day = now()->subDays(31); $day->startOfDay()->lte(now()); $day->addDay() ) { $dates[] = [ 'day' => $day->format('Y-m-d'), 'total' => 0, ]; } // Get the result from the GROUP BY query $sales = $product->sales()->select(DB::raw('DATE(sale_at) as day, CAST(SUM(qty) AS UNSIGNED) as total')) ->where('sale_at', '>=', now()->subDays(31)) ->groupBy('day') ->get(); // Merge them return array_map(function ($date) use ($sales) { foreach ($sales as $sale) { if ($date['day'] === $sale['day']) { return $sale; } } }, $dates);
データベースに関する投稿をさらに読みたい場合は、以下の記事をご覧ください:
- SQL データベースをスケーリングする方法
- MySQL テーブルを複製する方法
- 解決済み - 整合性制約違反
- Laravel Eager Loading で 1 日あたり 120 万クエリを節約
- スマート SQL クエリでアプリケーションのパフォーマンスを高速化する方法
- ORM パフォーマンスを最適化してアプリケーションをスケーラブルにします
- 解決済み – Laravel キューとジョブを使用すると MySQL ロック待機タイムアウトを超過しました
PHP アプリケーションを無料で監視する
Inspector は、ソフトウェア開発者向けに特別に設計されたコード実行監視ツールです。クラウド インフラストラクチャに何もインストールする必要はありません。Laravel パッケージをインストールするだけで準備完了です。
Inspector は非常に使いやすく、設定は必要ありません。
HTTP モニタリング、クエリ分析、アラートや通知を好みのメッセージング環境に転送する機能をお探しの場合は、Inspector を無料でお試しください。 [アカウントを登録+(https://app.inspector.dev/register).
または、Web サイトで詳細をご覧ください: https://inspector.dev
以上がMySQL を使用してヒストグラム チャートを作成する – チュートリアルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











tosecurelyconnecttoaremotemysqlserver、usesshtunneling、configuremysqlforremoteacess、setfirewallrules、andconsidersslencryption .first、Encistishansshtunnelwithssh-l3307:localhost:3306user@remote-server-nandconnectviamysql-h127.0.0.1-p3307.second、editmys

MySQLのBINディレクトリをシステムパスに追加するには、異なるオペレーティングシステムに従って構成する必要があります。 1。Windowsシステム:MySQLインストールディレクトリでビンフォルダーを見つけます(デフォルトパスは通常C:\ programfiles \ mysql \ mysqlserverx.x \ binです)、「このコンピューター」→「プロパティ」→「高度なシステム設定」→「高度なシステム設定」→「環境バリエブル」、「環境バリアブル」、Mysqlbinを節約します。コマンドプロンプトとmysql-versionの検証を入力します。 2.MacosおよびLinuxシステム:Bashユーザー編集〜/.Bashrcまたは〜/.bash_

MySQLDUMPは、MySQLデータベースの論理バックアップを実行するための一般的なツールです。データベースを再構築するための作成および挿入ステートメントを含むSQLファイルを生成します。 1.元のファイルをバックアップするのではなく、データベースの構造とコンテンツをポータブルSQLコマンドに変換します。 2。小さなデータベースや選択的回復に適しており、TBレベルのデータの迅速な回復には適していません。 3.一般的なオプションには、-single-Transaction、 - database、 - all-database、 - routinesなどが含まれます。 4. MySQLコマンドを使用して回復中にインポートし、外部キーチェックをオフにして速度を向上させることができます。 5.バックアップを定期的にテストし、圧縮と自動調整を使用することをお勧めします。

MySQLスロークエリログをオンにし、位置づけ可能なパフォーマンスの問題を分析します。 1.構成ファイルを編集するか、動的にSLOW_QUERY_LOGおよびLONG_QUERY_TIMEを設定します。 2。ログには、query_time、lock_time、rows_examinedなどの重要なフィールドが含まれており、効率のボトルネックの判断を支援します。 3. mysqldumpslowまたはpt-query-digestツールを使用して、ログを効率的に分析します。 4.最適化の提案には、インデックスの追加、Select*の回避、複雑なクエリの分割などが含まれます。たとえば、user_idにインデックスを追加すると、スキャンされた行の数を大幅に削減し、クエリ効率を改善できます。

mysqlでnull値を処理する場合、次の手に注意してください。1。テーブルを設計する場合、キーフィールドはnotnullに設定され、オプションのフィールドはnullを許可されます。 2。ISNULLまたはISNOTNULLは、=または!=;で使用する必要があります。 3. IFNULLまたはCoalesce関数を使用して、表示のデフォルト値を置き換えることができます。 4.挿入または更新時にnull値を直接使用する場合は注意し、データソースとORMフレームワークの処理方法に注意を払ってください。 nullは未知の値を表し、それ自体を含む値と等しくありません。したがって、テーブルをクエリ、カウント、および接続するときは、データや論理エラーの欠落を避けるときは注意してください。関数と制約の合理的な使用は、ヌルによる干渉を効果的に減らすことができます。

foreignkeysinmysqlensuredategritybyenforcingrelationshipsbetweentables.thepreventorphanedrecords、restrictinvaliddataentry、andcancascadechangesautomativitive.mustusetheetheintein nodbstorageine、およびforeidmatekolumnsmatchedtatepeofeofeofefe

MySQLのルートパスワードをリセットするには、次の手順に従ってください。1。mysqlサーバーを停止し、sudosystemctlstopmysqlまたはsudosystemctlstopmysqldを使用してください。 2。-skip-grant-tablesモードでmysqlを起動し、sudomysqld-skip-grant-tablesを実行します&; 3. mysqlにログインし、対応するsqlコマンドを実行して、flushprivilegesなどのバージョンに従ってパスワードを変更します。

MySQLバージョンを確認するには、Windowsコマンドプロンプトで次のメソッドを使用できます。1。コマンドラインを使用して直接表示するには、mysql - versionまたはmysql-vを入力します。 2。MySQLクライアントにログインした後、SelectVersion();; 3.インストールパスを手動で検索し、mysql binディレクトリに切り替えて、mysql.exe - versionを実行します。これらの方法はさまざまなシナリオに適しており、最初の2つは最も一般的に使用され、3番目の方法は環境変数が構成されていない状況に適しています。
