簡體   English   中英

Codeigniter 4 查詢生成器連接僅從第一個表顯示 1 次

[英]Codeigniter 4 query builder join display only 1 time from first table

我已經使用連接完成了一個查詢構建器。 我想根據表 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 關聯的所有記錄,我該怎么辦?

這是我當前的代碼:

Controller

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;
    }

Model:

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 次? 希望有人可以在這里幫助我。 提前謝謝各位!

實現這一點的最簡單方法(顯示 add_game 表中的 2 條記錄和 users 表中的 1 條記錄)您需要在視圖中創建一個 foreach 循環,並從要顯示的用戶表中排除重復數據。

controller:

$data['my_data']=$this->Your_model->your_method(); // your query example
$this->load->view('your_view',$data)

看法:

<?php $my_id=0;foreach($my_data as $row):?>
   <?php if($my_id!=$row->user_id):?>
     <div><?=$row->username?></div>   <!--data from table user-->
     <div><?=$row->created_at?></div> <!--data from table add_game-->
   <?php else:?>
     <div><?=$row->created_at?></div> <!--only data from table add_game-->
   <?php endif;?>
<?php $my_id=$row->user_id;endforeach;?>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM