I am trying to create an easy-to-use singleton class to connect to the mysql database and make queries, the code works fine and I had no problems with it, but since I'm new to OOP, I think it's bad practice or not.
Here is the class
class Database {
private $databaseName = 'dbname';
private $host = 'localhost';
private $user = 'user';
private $password = 'pass';
private static $instance;
private function __construct(){
$connection = mysql_connect($this->host, $this->user, $this->password) or die (mysql_error());
$db = mysql_select_db($this->databaseName, $connection) or die(mysql_error());
echo 'DB initiated<br>';
}
public static function getInstance(){
if(!self::$instance){
self::$instance = new Database();
}
return self::$instance;
}
public function connect() {
}
public function query($query) {
$sql = mysql_query($query) or die(mysql_error());
return $sql;
}
public function numrows($query) {
$sql = $this->query($query);
return mysql_num_rows($sql);
}
}
$database = Database::getInstance();
and when I want to use the class, I would do:
$query = "SELECT * FROM registrations";
echo $database->numrows($query);
$sql = $database->query($query);
source
share