A continuación se muestra la clase de conexión db Salí con hasta ahora, pero voy a mejorarlo mediante la extensión de la propia clase DOP,extender la clase DOP
<?php
class database
{
protected $connection = null;
#make a connection
public function __construct($hostname,$dbname,$username,$password)
{
try
{
# MySQL with PDO_MYSQL
$this->connection = new PDO("mysql:host=$hostname;dbname=$dbname", $username, $password);
$this->connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
catch (PDOException $e)
{
$this->connection = null;
die($e->getMessage());
}
}
#get the number of rows in a result
public function num_rows($query)
{
# create a prepared statement
$stmt = $this->connection->prepare($query);
if($stmt)
{
# execute query
$stmt->execute();
return $stmt->rowCount();
}
else
{
return self::get_error();
}
}
#display error
public function get_error()
{
$this->connection->errorInfo();
}
# closes the database connection when object is destroyed.
public function __destruct()
{
$this->connection = null;
}
}
?>
clase extendida,
class database extends PDO
{
#make a connection
public function __construct($hostname,$dbname,$username,$password)
{
parent::__construct($hostname,$dbname,$username,$password);
try
{
$this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
catch (PDOException $e)
{
die($e->getMessage());
}
}
#get the number of rows in a result
public function num_rows($query)
{
# create a prepared statement
$stmt = parent::prepare($query);
if($stmt)
{
# execute query
$stmt->execute();
return $stmt->rowCount();
}
else
{
return self::get_error();
}
}
#display error
public function get_error()
{
$this->connection->errorInfo();
}
# closes the database connection when object is destroyed.
public function __destruct()
{
$this->connection = null;
}
}
esta es la forma en que una instancia de la clase,
# the host used to access DB
define('DB_HOST', 'localhost');
# the username used to access DB
define('DB_USER', 'root');
# the password for the username
define('DB_PASS', 'xxx');
# the name of your databse
define('DB_NAME', 'db_2011');
include 'class_database.php';
$connection = new database(DB_HOST,DB_NAME,DB_USER,DB_PASS);
$sql = "
SELECT *
FROM root_contacts_cfm
ORDER BY cnt_id DESC
";
$connection->num_rows($sql);
Pero tengo errores cuando llamo a esta clase PDO extendida,
Warning: PDO::__construct() expects parameter 4 to be array, string given in C:\wamp\www\xx\class_database.php on line xx
Fatal error: Call to a member function setAttribute() on a non-object in C:\wamp\www\xx\class_database.php on line xx
he hecho un poco de investigación en línea, me encontré con esta estructura básica de la DOP se extiende, pero no entiendo que ...
class myPDO extends PDO
{
public function __construct($dsn,
$username=null,
$password=null,
$driver_options=null)
{
parent::__construct($dsn, $username, $password, $driver_options);
}
public function query($query)
{
$result = parent::query($query);
// do other stuff you want to do here, then...
return($result);
}
}
¿Cuál es $ds
n variable para? ¿Cómo puedo pasar mi variable $hostname
a la clase extendida de pdo?
Otras preguntas: ¿Cómo puedo hacer un método para mostrar el error en la clase extendida de pdo? ¿Cómo puedo cerrar la conexión en la clase extendida de pdo?
¡Es tan difícil moverse de mysqli a pdo!
Gracias.
Mirando lo que has escrito, realmente no necesitas extender la clase PDO. Solo lo estás haciendo más difícil de lo necesario. –
está extendiendo pdo una mala cosa? Tuve una clase de mysqli independiente antes, pero me dijeron que era mejor extender mysqli así que pensé que debía ser lo mismo que pdo ?? – laukok
No necesita volver a escribir el constructor por cierto. –