2

我正在使用Paris(它建立在Idiorm 之上)。

我有以下模型类(示例来自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
}

不幸的是,这会为每次迭代创建一个查询。有没有办法告诉 Paris 或 Idiorm 在第一个 find_many 查询中获取相关信息?

您应该如何使用 Paris 检索信息以最大程度地减少查询次数?我不想手动指定连接条件(这就是我使用 Paris 而不是 Idiorm 的原因)

4

2 回答 2

4

我是 Paris 和 Idiorm 项目的当前维护者。不幸的是,您在这里描述的是自定义查询的案例,而不是 Paris 旨在解决的问题。Paris and 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 %}

但它只有在您没有在一页上显示数百个帖子时才有效。

于 2017-09-10T19:12:43.987 回答