ThinkPHP6の結合テーブル集計クエリを例から解説
先日、友人からジョイントテーブルの集計クエリについて質問されたのですが、この問題は多くの初心者には難しいのではないかと思い、共有したいと思います。
2 つのデータ テーブルがあります:
バス テーブル:
##ユーザー テーブル:
要件: バスに乗る人の数を数える
これを達成するにはどうすればよいですか?#ステップ 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 つのデータテーブル。
集計クエリを実行する前に、公式マニュアルチュートリアル。
最終的に統計の数を取得したいため、最初に count() メソッドを使用することを決定し、クエリ ステートメントを変更します。
$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c'')->join('bus b','a.user_id=b.user_id')->select()->toArray();
$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();
上記のクエリ ステートメントでは、mysql のバージョンが 5.7 の場合、特別な料金を支払う必要があります。注意。たとえば、mysql5.7 のフィールドに a.* を追加すると、次のようなエラーが報告されます。
MYSQL5.7 には、パフォーマンス向上のため sql_mode に制限があります。
ONLY_FULL_GROUP_BY: GROUP BY 集計操作の場合、SELECT の列が GROUP BY にない場合、その列が GROUP BY 句にないため、この SQL は無効であり、エラーになります。
mysql 設定を変更できます:
/etc/my.cnf を変更し、sql_mode でonly_full_group_by を削除します= この方法で, 結合テーブルの集計クエリが実現されていますが、この問題に遭遇しても焦らず、最終的なニーズに応じて段階的に分割して実装していきます。
以上がThinkPHP6の結合テーブル集計クエリを例から解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック







