कोडिग्निटर 4 अपरिभाषित सूचकांक: user_id

Aug 16 2020

मैं "ज्वाइन" परिणाम दिखाने की कोशिश कर रहा हूं और केवल उपयोगकर्ता तालिका दिखाने के लिए उपयोगकर्ता_आईडी, उपयोगकर्ता नाम, ईमेल दिखाना चाहता हूं, भले ही अन्य तालिका में कई रिकॉर्ड हों, इसलिए मैंने नीचे की तरह एक क्वेरी बिल्डर बनाने की कोशिश की:

Table users                          | Table add_game
                                     |
user_id | username | email           | game_id | user_id | ign    | acc_id

1       | userA    | [email protected] | 1       | 1       | ignA   | accA
2       | userB    | [email protected] | 2       | 1       | ignB   | accB
                                     | 1       | 2       | ignB   | accB
                                     | 3       | 2       | ignD   | accD 

नमूना :

<?php namespace App\Models;

use CodeIgniter\Database\ConnectionInterface;

class LoginModel{
    
    protected $db; public function __construct(ConnectionInterface &$db){
        $this->db =& $db;
    }


    public function login(string $str) { return $this->db->table('users')
                        
                        ->groupStart()
                            ->where('username', $str) ->orWhere('email', $str)
                        ->groupEnd()
                        
                        ->join('add_game', 'add_game.user_id = users.user_id')
                        //->distinct('users.user_id')
                        //->select(("GROUP_CONCAT(game_id, ign, acc_id) AS userdata"))
                        ->get()
                        ->getResultArray();
    }
    
}

नियंत्रक:

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);
        
            echo view('templates/header', $data); echo view('account/login', $data);
            echo view('templates/footer', $data); } 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;
    }

लेकिन अभी मुझे मिल रहा है

अनिर्धारित सूचकांक: user_id

त्रुटि संदेश। पहले कोई समस्या या त्रुटि नहीं थी जब मैं अपने लॉगिन के लिए क्वेरी बिल्डर के बिना उपयोग कर रहा था:

public function login(string $str, string $fields, array $data) { return $this->where('username', $data['userlogin'])->orWhere('email', $data['userlogin'])
                                  ->first();
    }

इस त्रुटि को कैसे हल करें?

जवाब

1 Vickel Aug 16 2020 at 17:50

आपकी टिप्पणी (छवि) के अनुसार आपका सरणी ऐसा दिखता है:

Array
(
  [0]=>Array
    (
      [user_id]=>1,
      [user_name]=>'test',
      //etc.
    )
)

आप प्राप्त करें

अनिर्धारित सूचकांक: user_id

त्रुटि संदेश का उपयोग करते समय गलत तरीके से संबोधित करने के कारण 'user_id' => $user['user_id']

सही तरीका यह है कि आप जिस इंडेक्स को जोड़ना चाहते हैं उसे जोड़ें:

$this->setUserSession($user[0]);   // where 0 can be changed to the index you pretend

अब सरणी चपटा है और 'user_id' => $user['user_id']अब कोई त्रुटि नहीं करता है।