我有以下模型类(示例来自documentation on 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而不是Idiorm的原因)
答案 0 :(得分:3)
我是巴黎和Idiorm项目的现任维护者。不幸的是,你在这里描述的是自定义查询的情况,而不是巴黎曾经构建过来解决的问题。巴黎和Idiorm的理念是尽可能接近80/20原则,你的用例是在20。
知道你最终如何解决这个问题会很有趣。
答案 1 :(得分: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 %}
但只有当你没有在一个页面上显示数百个帖子时它才有效。