結合 (チェーン操作 11)
join には通常、次のタイプがあります。さまざまなタイプの結合操作は、返されるデータの結果に影響します。
1.INNER JOIN: JOIN (デフォルトの JOIN タイプ) と同等。テーブル内に少なくとも 1 つの一致がある場合、行が返されます。
2.LEFT JOIN: 一致するものがあった場合でも、行が返されます。右のテーブルに一致がない場合は、左のテーブルのすべての行を返します
3.RIGHT JOIN: 左のテーブルに一致がない場合でも、右のテーブルのすべての行を返します
4.FULL JOIN: いずれかのテーブルに一致がある限り、一致がある場合は行を返します。
#Description
join ( mixed join [, mixed $condition = null [, string $type = 'INNER']] ) leftJoin ( mixed join [, mixed $condition = null ] ) rightJoin ( mixed join [, mixed $condition = null ] ) fullJoin ( mixed join [, mixed $condition = null ] )
パラメータ
join
要关联的(完整)表名以及别名
サポートされる書き込み方法:
書き込み方法 1: ['完全なテーブル名またはサブクエリ'=>'エイリアス']
書き込み方法 2:'データ テーブルの接頭辞のないテーブル名' (別名として自動的に使用されます)
書き方 2:'データ テーブルの接頭辞のないテーブル名の別名'
条件
关联条件。可以为字符串或数组, 为数组时每一个元素都是一个关联条件。
type
关联类型。可以为:`INNER`、`LEFT`、`RIGHT`、`FULL`,不区分大小写,默认为`INNER`。
戻り値
Model object
Example
Db::table('think_artist') ->alias('a') ->join('work w','a.id = w.artist_id') ->join('card c','a.card_id = c.id') ->select();
Db::table('think_user') ->alias('a') ->join(['think_work'=>'w'],'a.id=w.artist_id') ->join(['think_card'=>'c'],'a.card_id=c.id') ->select();
INNER JOIN メソッドはデフォルトで使用されます。他の JOIN メソッドを使用する必要がある場合は、これを
Db::table('think_user') ->alias('a') ->leftJoin('word w','a.id = w.artist_id') ->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();
にすることもできます。