在简单的场景下,redbean中的多对多映射很容易使用。但是,如何在同一个对象之间进行多对多映射?
示例:
我想要完成的是与“追随者”和“追随者”的推特/ Instagram设置非常类似的结构
// this c
$user = R::dispense('user');
$user2 = R::dispense('user');
// ..
//Usr1 follows user2
$user->sharedUser[] = $user2;
// user2 follows user1
$user2->sharedUser[] = $user1;
现在,我想从user1的角度列出关注者和以下用户。
但是,我无法列出“关注者”,而无需查询数据库中的所有用户并查找user1。有没有办法在redbean中有多个“共享”列表,或者对于这些特定情况有任何好的解决方法,或者查询方式是什么?
答案 0 :(得分:6)
以下是我与测试一起使用的代码,以证明它有效:)
<?php
include_once 'rb.php';
R::setup();
//create users
$users = array();
foreach (array('arul', 'jeff', 'mugunth', 'vish') as $name) {
$user = R::dispense('user');
$user->name = $name;
$user->follows = R::dispense('follows');
//create variables with specified names ($arul, $jeff, etc)
$$name = $user;
$users[] = $user;
}
//set relationships
$arul->follows->sharedUser = array($jeff);
$mugunth->follows->sharedUser = array($jeff, $arul);
$vish->follows->sharedUser = array($arul, $mugunth);
R::storeAll($users);
//print relationships
$id = 1;
while (true) {
echo "-----------------------------------\n";
$u = R::load('user', $id++);
if (!$u->id) break;
echo "$u->name follows " . count($u->follows->sharedUser) . " user(s) \n";
if ($u->follows) {
foreach ($u->follows->sharedUser as $f) {
echo " - $f->name \n";
}
}
echo "\n$u->name is followed by "
. R::getCell("SELECT COUNT(*) FROM follows_user WHERE user_id = $u->id")
. " user(s) \n";
foreach ($u->sharedFollows as $f) {
$follower = array_shift($f->ownUser);
echo " - $follower->name \n";
}
}
/* echos the following
-----------------------------------
jeff follows 0 user(s)
jeff is followed by 2 user(s)
- arul
- mugunth
-----------------------------------
arul follows 1 user(s)
- jeff
arul is followed by 2 user(s)
- mugunth
- vish
-----------------------------------
mugunth follows 2 user(s)
- jeff
- arul
mugunth is followed by 1 user(s)
- vish
-----------------------------------
vish follows 2 user(s)
- arul
- mugunth
vish is followed by 0 user(s)
-----------------------------------
*/