CakePHP の find メソッドと JOIN を使用して複数のテーブルからデータを取得する方法

Mary-Kate Olsen
リリース: 2024-10-17 22:34:02
オリジナル
267 人が閲覧しました

How to Retrieve Data from Multiple Tables Using CakePHP\'s find Method with JOIN?

Retrieve Data from Multiple Tables Using CakePHP's find Method with JOIN

To execute the specified SQL query using CakePHP's find method, you can employ two approaches:

Method 1: CakePHP Standard Approach

  1. Establish relationships between your models:
<code class="php">class User extends AppModel {
    public $actsAs = array('Containable');
    public $hasMany = array('Message');
}

class Message extends AppModel {
    public $actsAs = array('Containable');
    public $belongsTo = array('User');
}</code>
ログイン後にコピー
  1. Define relationships properly:
  2. Rename messages.from column to messages.user_id for auto-association.
  3. Execute the query:
<code class="php">$this->Message->find('all', array(
    'contain' =&gt; array('User')
    'conditions' =&gt; array(
        'Message.to' =&gt; 4
    ),
    'order' =&gt; 'Message.datetime DESC'
));</code>
ログイン後にコピー

Method 2: Custom Join

  1. Define custom join parameters:
<code class="php">$this->Message->find('all', array(
    'joins' =&gt; array(
        array(
            'table' =&gt; 'users',
            'alias' =&gt; 'UserJoin',
            'type' =&gt; 'INNER',
            'conditions' =&gt; array(
                'UserJoin.id = Message.from'
            )
        )
    ),
    'conditions' =&gt; array(
        'Message.to' =&gt; 4
    ),
    'fields' =&gt; array('UserJoin.*', 'Message.*'),
    'order' =&gt; 'Message.datetime DESC'
));</code>
ログイン後にコピー

Using Multiple Relationships to the Same Model

You can establish two relationships to the same model:

<code class="php">class User extends AppModel {
    public $actsAs = array('Containable');
    public $hasMany = array(
        'MessagesSent' =&gt; array(
            'className'  =&gt; 'Message',
            'foreignKey' =&gt; 'from'
         )
    );
    public $belongsTo = array(
        'MessagesReceived' =&gt; array(
            'className'  =&gt; 'Message',
            'foreignKey' =&gt; 'to'
         )
    );
}

class Message extends AppModel {
    public $actsAs = array('Containable');
    public $belongsTo = array(
        'UserFrom' =&gt; array(
            'className'  =&gt; 'User',
            'foreignKey' =&gt; 'from'
        )
    );
    public $hasMany = array(
        'UserTo' =&gt; array(
            'className'  =&gt; 'User',
            'foreignKey' =&gt; 'to'
        )
    );
}</code>
ログイン後にコピー

Example query:

<code class="php">$this->Message->find('all', array(
    'contain' =&gt; array('UserFrom')
    'conditions' =&gt; array(
        'Message.to' =&gt; 4
    ),
    'order' =&gt; 'Message.datetime DESC'
));</code>
ログイン後にコピー

以上がCakePHP の find メソッドと JOIN を使用して複数のテーブルからデータを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!