0

I am trying to display some information from database and I have the following two files. When I run the index.php , I get this error:Fatal error: Call to a member function prepare() on a non-object in C:\xampp\htdocs\pc\index.php on line 16

Could you please tell me how to solve this problem

index.php

include_once('database.php');

$db= new database();
$conn = $db->connect();
                         //Problem is in the folloing line
$query = $conn->prepare('SELECT * FROM admin WHERE admin_id = :id'); 
$query->execute(array('id' => 1));
?>
<table>
<tr>
<th>Name</th>
<th>Email</th>
</tr>

<?php
while( $rows = $query->fetch(PDO::FETCH_ASSOC)) {
    echo "<tr>";
    echo "<td>". $rows['admin_name'] ."</td>" ;
    echo "<td>". $rows['admin_email'] ."</td>" ;

    echo "</tr>";
}
?>

</table>

database.php

class Database{

private $host = 'localhost';
private $dbname = 'school';
private $username = 'root';
private $password ='';  

public $con = '';

function __construct(){

    $this->connect();   

}

function connect(){

    try{

        $this->con = new PDO("mysql:host=$this->host;dbname=$this->dbname",$this->username, $this->password);
        $this->con->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);


    }catch(PDOException $e){

        echo 'We\'re sorry but there was an error while trying to connect to the database';
        file_put_contents('connection.errors.txt', $e->getMessage().PHP_EOL,FILE_APPEND);

    }
}   
}

1 Answer 1

2
class Database{

private $host = 'localhost';
private $dbname = 'school';
private $username = 'root';
private $password ='';  

public $con = '';

function __construct(){

    $this->connect();   

}

function connect(){

    try{

        $this->con = new PDO("mysql:host=$this->host;dbname=$this->dbname",$this->username, $this->password);
        $this->con->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);


    }catch(PDOException $e){

        echo 'We\'re sorry but there was an error while trying to connect to the database';
        file_put_contents('connection.errors.txt', $e->getMessage().PHP_EOL,FILE_APPEND);

    }
    return $this->con; // This makes all the magic!!!
}   
}
Sign up to request clarification or add additional context in comments.

2 Comments

Thanks a lot for your answer. It was indeed a magic :) If you don't mind .. could you please tell me how to stop loading the codes after $conn = $db->connect(); in index.php if there was a problem connecting the db? Thanks :)
@black_belt within the catch block you can die('failed'); or however you want to do that, otherwise, check $conn for is_a of PDO as if(!is_a($conn, 'PDO')) { /*kill here*/ } after $conn = $db->connect();

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.