結合 (チェーン操作 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();

にすることもできます。