thinkphp5 での join の使用法は何ですか?
thinkphp5 では、結合は、テーブル内の列間の関係に基づいて 2 つ以上のテーブルのデータをクエリするために使用されます。これは、コヒーレントな操作メソッドの 1 つです。返される結果はモデル オブジェクトです。構文は " join(関連付けるテーブル名と別名[関連条件[関連タイプ]])」。
この記事の動作環境: Windows 10 システム、ThinkPHP バージョン 5、Dell G3 コンピューター。
thinkphp5 での join の使用法とは何ですか
JOIN メソッドもコヒーレント操作メソッドの 1 つで、テーブル内の列間の関係に基づいて 2 つ以上のテーブルからクエリを実行するために使用されます。これらのテーブル、データ。
説明
object join ( mixed join [, mixed $condition = null [, string $type = 'INNER']] )
パラメータ
join: 関連付けられる(完全な)テーブル名と別名は、3つの記述方法をサポートします:
書き方 1: ['完全なテーブル名またはサブクエリ'=>'エイリアス']
書き方 2:'完全なテーブル名のエイリアス'
-
書き込み 3: 'データテーブルプレフィックスのないテーブル名'
condition: アソシエーション条件。文字列または配列にすることができ、配列の場合、各要素は関連付けられた条件になります。
type: アソシエーションタイプ。指定できるのは次のとおりです: INNER、LEFT、RIGHT、FULL、大文字と小文字は区別されません。デフォルトは INNER です。
戻り値: モデル オブジェクト
結合には通常、次の型があります。結合操作の種類が異なると、返されるデータの結果に影響します。
INNER JOIN: JOIN (デフォルトの JOIN タイプ) と同等。テーブル内に少なくとも 1 つの一致がある場合、行が返されます
LEFT JOIN : 右のテーブルに一致するものがない場合でも、左のテーブルのすべての行を返します。
RIGHT JOIN: 一致するものがない場合でも、右のテーブルからすべての行を返します。左側のテーブル
FULL JOIN: いずれかのテーブルに一致がある限り、行が返されます。
例は次のとおりです。 :
Db::table('think_artist') ->alias('a') ->join('think_work w','a.id = w.artist_id') ->join('think_card c','a.card_id = c.id') ->select();
Db::table('think_artist') ->alias('a') ->join('__WORK__ w','a.id = w.artist_id') ->join('__CARD__ c','a.card_id = c.id') ->select();
$join = [ ['think_work w','a.id=w.artist_id'], ['think_card c','a.card_id=c.id'], ]; Db::table('think_user')->alias('a')->join($join)->select();
上記3つの書き方も同様で、__WORK__と__CARD__は最終分析時にthink_workとthink_cardに変換されます。注: 「_table name_」メソッドの途中にあるテーブル名は大文字である必要があります。
エイリアスを使用したくない場合は、後続のメソッドでテーブルの完全な名前を使用する必要があります。次のメソッドを使用できます。
Db::table('think_user')->join('__WORK__','__ARTIST__.id = __WORK__.artist_id')->select();
デフォルトでは INNER JOIN メソッドが使用されます。他の JOIN メソッドを使用する必要がある場合は、これを
Db::table('think_user')->alias('a')->join('word w','a.id = w.artist_id','RIGHT')->select();
に変更できます。テーブル名も使用できます。サブクエリであること
$subsql = Db::table('think_work')->where(['status'=>1])->field('artist_id,count(id) count')->group('artist_id')->buildSql(); Db::table('think_user')->alias('a')->join([$subsql=> 'w'], 'a.artist_id = w.artist_id')->select();
buildSql によって返されるステートメントには () が含まれるため、両端に () を追加する必要はありません。
推奨学習: 「PHP ビデオ チュートリアル 」
以上がthinkphp5 での join の使用法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。

ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。

「開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法」 インターネット技術の急速な発展に伴い、Web アプリケーションには、多数の同時リクエストと複雑なビジネス ロジックを処理するための要件がますます高まっています。システムのパフォーマンスとユーザー エクスペリエンスを向上させるために、開発者は多くの場合、電子メールの送信、ファイルのアップロードの処理、レポートの生成など、時間のかかる操作を実行するために非同期タスクの使用を検討します。 PHP の分野では、人気のある開発フレームワークとして ThinkPHP フレームワークが、非同期タスクを実装するための便利な方法をいくつか提供しています。

ThinkPHP のインストール手順: PHP、Composer、および MySQL 環境を準備します。 Composer を使用してプロジェクトを作成します。 ThinkPHP フレームワークと依存関係をインストールします。データベース接続を構成します。アプリケーションコードを生成します。アプリケーションを起動し、http://localhost:8000 にアクセスします。

ThinkPHP は、キャッシュ メカニズム、コードの最適化、並列処理、データベースの最適化などの利点を備えた高性能 PHP フレームワークです。公式パフォーマンステストでは、1秒あたり10,000以上のリクエストを処理できることが示されており、実際のアプリケーションではJD.comやCtripなどの大規模なWebサイトやエンタープライズシステムで広く使用されています。

開発の提案: API 開発に ThinkPHP フレームワークを使用する方法 インターネットの継続的な発展に伴い、API (アプリケーション プログラミング インターフェイス) の重要性がますます高まっています。 API は、異なるアプリケーション間の通信の橋渡しとなるもので、データの共有や関数の呼び出しなどを実現し、開発者に比較的簡単かつ迅速な開発手法を提供します。優れた PHP 開発フレームワークである ThinkPHP フレームワークは、効率的でスケーラブルで使いやすいです。
