我已经使用连接完成了一个查询构建器。我想根据表 1 上的用户 ID 显示表 2、3、4、5、6 等。我尝试查询结果,它显示如下:
我的桌子
Table users
user_id | username | email
1 | userA | userA@email.com
2 | userB | userB@gmail.com
Table add_game
game_id | user_id | ign | acc_id
1 | 1 | ignA | accA
2 | 1 | ignB | accB
1 | 2 | ignB | accB
3 | 2 | ignD | accD
我将使用 foreach 循环,我相信它会根据数据库中的记录多次显示。如果我只想显示红色框中突出显示的信息(来自 users 表)仅 1 次以及 add_game 表中与 user id 关联的所有记录,我该怎么办?
这是我当前的代码:
控制器
public function login()
{
$data = [];
helper(['form']);
$validation = \Config\Services::validation();
$db = db_connect();
$model = new LoginModel($db);
$user = $model->login($this->request->getVar('userlogin'));
$this->setUserSession($user[0]);
echo view('templates/header', $data, $user);
echo view('account/login', $data, $user);
echo view('templates/footer', $data, $user);
}
private function setUserSession($user){
$data = [
'user_id' => $user['user_id'],
'username' => $user['username'],
'email' => $user['email'],
'firstname' => $user['firstname'],
'lastname' => $user['lastname'],
'dob' => $user['dob'],
'country' => $user['country'],
'country_code' => $user['c_code'],
'contact' => $user['contact'],
'game_id' => $user['game_id'],
'ign' => $user['ign'],
'acc_id' => $user['acc_id'],
'isLoggedIn' => true
];
session()->set($data);
return true;
}
模型:
return $this->db->table('users')
->groupStart()
->where('username', $str)
->orWhere('email', $str)
->groupEnd()
->join('add_game', 'add_game.user_id = users.user_id')
->get()
->getResultArray();
我还有几张桌子,但现在还没有创建,所以我暂时只加入了一张桌子。我错过了什么?还是我必须循环两次?有没有一种方法我只需要循环 1 次?希望有人可以在这里帮助我。提前谢谢各位!