Print_r ve foreach farklı sonuçlar veriyor

0 Cevap php

Ben veritabanından kullanıcı adı ve kullanıcı kimlikleri getirir bir pdo işlevi var. Ben işlevini çalıştırdığınızda i farklı sonuçlar elde.

print_r verir

Array ([ID] => 58 [kullanıcı adı] => Abdullatif)

ve foreach bana verir

5-5a-a

Veritabanında pdo sorgusuna bir satır vardır.

public function getUserCredentials($userName, $password){
$this->db   = new Dbpdo_Database(); 
$this->db->connect();
try{  
    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    $stmt = $dbh->prepare("SELECT 
            ID 
          FROM 
            administrators 
          WHERE 
            username = :username 
          AND 
            user_password = :password
          LIMIT 1");  


    $stmt->bindParam(':username', $userName, PDO::PARAM_STR);
    $stmt->bindParam(':password', $password, PDO::PARAM_STR);
    }

    $stmt->execute();

    /*** fetch the results ***/
    $results = $stmt->fetchAll(PDO::FETCH_ASSOC);

    return $results;

    /*** close the database connection ***/
    //$dbh = null;
}
catch(PDOException $e){
    echo $e->getMessage();
  } 
}

$results = $mydb->getUserCredentials($userName, $password);

foreach ($results as $row){
echo $row['ID'].'-'.$row['username'];
}

print_r($results);

Ne yanlış olarak herhangi bir ipuçları çok takdir. Şimdiden teşekkürler.

0 Cevap