検索
ホームページPHPフレームワークThinkPHPThinkPHP6の結合テーブル集計クエリを例から解説

先日、友人からジョイントテーブルの集計クエリについて質問されたのですが、この問題は多くの初心者には難しいのではないかと思い、共有したいと思います。

2 つのデータ テーブルがあります:

バス テーブル: ThinkPHP6の結合テーブル集計クエリを例から解説

##ユーザー テーブル:

ThinkPHP6の結合テーブル集計クエリを例から解説

要件: バスに乗る人の数を数える

これを達成するにはどうすればよいですか?

#ステップ 1: テーブルの結合#このシナリオでは、必ず 2 つのデータ テーブルを結合する必要があります。統計を最初に考慮するのではなく、2 つのデータ テーブルを結合します。

 $data=Db::name('user')->alias('a')->join('bus b','a.user_id=b.user_id')->select()->toArray();

alias はエイリアス、join はジョイント テーブルのデータ テーブル、ジョイント テーブル条件 a.user_id=b.user_id があるため、 2 つのデータテーブル。

ThinkPHP6の結合テーブル集計クエリを例から解説

#ステップ 2: 集計クエリ

集計クエリを実行する前に、公式マニュアルチュートリアル。

最終的に統計の数を取得したいため、最初に count() メソッドを使用することを決定し、クエリ ステートメントを変更します。 ThinkPHP6の結合テーブル集計クエリを例から解説

$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c'')->join('bus b','a.user_id=b.user_id')->select()->toArray();

このうち c はエイリアスです。

user_id フィールドに基づいて集計クエリを実行する必要があります。統計はこのフィールドに基づいているため、group(user_id)、つまり user_id フィールドに従ってグループ化する必要があります。

クエリ ステートメントの変更を続けます:

$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c')->join('bus b','a.user_id=b.user_id')->group('a.user_id')->select()->toArray();

このようにして、最終的なクエリ結果が得られます。

3 番目のポイント: 状況に注意してください

上記のクエリ ステートメントでは、mysql のバージョンが 5.7 の場合、特別な料金を支払う必要があります。注意。たとえば、mysql5.7 のフィールドに a.* を追加すると、次のようなエラーが報告されます。

MYSQL5.7 には、パフォーマンス向上のため sql_mode に制限があります。

ONLY_FULL_GROUP_BY: GROUP BY 集計操作の場合、SELECT の列が GROUP BY にない場合、その列が GROUP BY 句にないため、この SQL は無効であり、エラーになります。 ThinkPHP6の結合テーブル集計クエリを例から解説

mysql 設定を変更できます:

/etc/my.cnf を変更し、sql_mode でonly_full_group_by を削除します= この方法で, 結合テーブルの集計クエリが実現されていますが、この問題に遭遇しても焦らず、最終的なニーズに応じて段階的に分割して実装していきます。

以上がThinkPHP6の結合テーブル集計クエリを例から解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Think BookとThinkPadの違いは何ですかThink BookとThinkPadの違いは何ですかMar 06, 2025 pm 02:16 PM

この記事では、LenovoのThinkbookとThinkPadラップトップのラインを比較します。 ThinkPadsは、専門家の耐久性とパフォーマンスを優先しますが、ThinkBooksは毎日の使用にスタイリッシュで手頃な価格のオプションを提供します。 重要な違いは、ビルド品質にあります

SQLインジェクションチュートリアルを防ぐ方法SQLインジェクションチュートリアルを防ぐ方法Mar 06, 2025 pm 02:10 PM

この記事では、ThinkPhpアプリケーションでのSQL注入を防ぐ方法について説明します。 ThinkPhpのクエリビルダーを介してパラメーター化されたクエリを使用し、直接SQLの連結を避け、堅牢な入力検証と消毒を実装することを強調しています。 広告

ThinkPhpの脆弱性に対処する方法は?ThinkPhpの脆弱性に対処する方法は?Mar 06, 2025 pm 02:08 PM

この記事では、パッチング、予防、および監視を強調し、ThinkPhpの脆弱性について説明します。 更新、セキュリティパッチ、およびコード修正を介して特定の脆弱性の処理を詳述します。 安全な構成、入力などのプロアクティブな測定

ThinkPhpによって開発されたソフトウェアのインストール方法チュートリアルをインストールする方法ThinkPhpによって開発されたソフトウェアのインストール方法チュートリアルをインストールする方法Mar 06, 2025 pm 02:09 PM

この記事では、ThinkPhpソフトウェアのインストールを詳しく説明し、ダウンロード、抽出、データベースの構成、許可確認などの手順をカバーしています。 システム要件(PHPバージョン、Webサーバー、データベース、拡張機能)に対応し、共通インストール

thinkphpの脆弱性を修正する方法thinkphpの脆弱性に対処する方法thinkphpの脆弱性を修正する方法thinkphpの脆弱性に対処する方法Mar 06, 2025 pm 02:04 PM

このチュートリアルは、一般的なThinkPHPの脆弱性に対応しています。 定期的な更新、セキュリティスキャナー(RIP、Sonarqube、Snyk)、手動コードレビュー、および識別と修復のための浸透テストを強調しています。 予防措置には安全が含まれます

ThinkPhpを使用してコマンドラインアプリケーションを構築するにはどうすればよいですか?ThinkPhpを使用してコマンドラインアプリケーションを構築するにはどうすればよいですか?Mar 12, 2025 pm 05:48 PM

この記事では、ThinkPhpのCLI機能を使用して、構築コマンドラインアプリケーション(CLI)を示しています。 INSUなどの一般的な落とし穴を強調しながら、モジュラー設計、依存関係注入、堅牢なエラー処理などのベストプラクティスを強調しています

ThinkPhpによってデータベースに接続する方法の詳細な手順ThinkPhpによってデータベースに接続する方法の詳細な手順Mar 06, 2025 pm 02:06 PM

このガイドは、database.phpを介した構成に焦点を当てたthinkphpのデータベース接続を詳しく説明しています。 PDOを使用し、ORMまたは直接SQL相互作用を可能にします。 ガイドは、共通の接続エラーのトラブルシューティング、複数の接続の管理、ENをカバーしています

ThinkPhpチュートリアルの使用方法ThinkPhpチュートリアルの使用方法Mar 06, 2025 pm 02:11 PM

この記事では、無料のオープンソースPHPフレームワークであるThinkPhpを紹介します。 ThinkPHPのMVCアーキテクチャ、機能(ルーティング、データベースインタラクション)、利点(迅速な発展、使いやすさ)、および短所(潜在的な過剰エンジニアリング、コミュニケーション)の詳細

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境