2

私はParis ( Idiormの上に構築されています) を使用しています。

私は次の Model クラスを持っています (例は github のドキュメントからインスピレーションを得ています):

<?php
class Post extends Model {
    public function user() {
        return $this->belongs_to('User');
    }
}

class User extends Model {
    public function posts() {
        return $this->has_many('Post'); // Note we use the model name literally - not a pluralised version
    }
}

だから今、私は次のことができます(うまくいきます):

// Select a particular user from the database
$user = Model::factory('User')->find_one($user_id);
// Find the posts associated with the user
$posts = $user->posts()->find_many();

// Select a particular post from the database
$post = Model::factory('Post')->find_one($post_id);
// Find the user associated with the post
$user = $post->user()->find_one();

しかし、私は次のこともやりたいです:

$posts = Model::factory('Post')->find_many();
foreach ($posts as $post) {
     echo($post->user()->find_one()->username); // generates a query each iteration
}

残念ながら、これは反復ごとにクエリを作成します。最初の find_many クエリで関連情報を取得するように Paris または Idiorm に指示する方法はありますか?

クエリの数を最小限に抑えるために、パリで情報を取得するにはどうすればよいですか? 結合条件を手動で指定する必要がないようにしたい (これが、Idiorm ではなく Paris を使用している理由です)

4

2 に答える 2

4

私は現在、Paris および Idiorm プロジェクトのメンテナーです。残念ながら、ここで説明するのはカスタムクエリのケースであり、パリが解決するために構築されたものではありません. Paris と Idiorm の哲学は、できるだけ 80/20 の原則に固執することであり、ユースケースは 20 です。

この問題をどのように解決したかを知ることは興味深いでしょう。

于 2013-01-15T15:38:35.170 に答える
0

私はまったく同じ問題を抱えていて、最終的にこの(少し醜い)解決策になりました:

$posts = Model::factory('Post')...->limit($perpage)->find_many();
$user_ids = $user_lookup = array();

foreach($posts as $post) $user_ids[] = $post->user_id;

$users = Model::factory('User')->where_id_in($user_ids)->find_many();
foreach($users as $user) $user_lookup[$user->id] = $user;

2つだけ選択。そして後でテンプレートで:

{% for post in posts %}
   <h2>{{ post.title }}</h2>
   by author: {{ user_lookup[post.user_id].username }}
{% endfor %}

ただし、1 ページに何百もの投稿が表示されていない場合にのみ機能します。

于 2017-09-10T19:12:43.987 に答える