Classe PEAR DB non trovata
-
11-10-2019 - |
Domanda
Ho creare una classe chiamata database.php per interagire con il database MySQL con classe PEAR DB.
database.php
<?php
require_once('DB.php');
require_once('cException.php');
class DataBase
{
private $dsn = 'mysql://root:xxxxxx@localhost/avatar';
private $conn;
//Constructor
function __construct()
{
global $conn;
$this->conn = DB::connect($dsn);
if(DB::isError($conn))
{
throw new DatabaseConnectionException();
}
}
//destructor
function __destruct()
{
$this->conn->disconnect();
}
public function select($query)
{
$conn->setFetchMode(DB_FETCHMODE_ASSOC);
$result = & $conn->query($query);
if(DB::isError($result))
{
return new SelectCommandException($result->getMessage());
}
return $result;
}
static public function instance()
{
static $objDB;
if(! isset($objDB))
{
$objDB = new DataBase();
}
return $objDB;
}
?>
E sto chiamando questa classe da un file di esempio test.php
test.php
<?php
ini_set('display_errors', 1);
ini_set('log_errors', 1);
ini_set('error_log', dirname(__FILE__) . '/error_log.txt');
error_reporting(E_ALL);
require_once 'Database.php';
try
{
$db = DataBase::instance();
}
catch (DatabaseConnectionException $ex1)
{
echo $ex1->toString();
}
try
{
$sql = "Select * from register";
$result = $db->select($sql);
var_dump($result);
}
catch (SelectCommandException $ex2)
{
echo $ex2->toString();
}
?>
Quando eseguo test.php ottengo il seguente errore
Attenzione: require_once (/usr/share/pear/DB.php): non è riuscito a flusso aperto: No such file or directory in /var/www/Avatar/Database.php sulla linea 2 Fatal error: require_once (): Failed apertura richiesto '/Usr/share/pear/DB.php' (Include_path = ': / usr / share / php: / usr / share / pear') in /var/www/Avatar/Database.php su linea 2
Non so perché sto ottenendo questo errore. In phpinfo () mostra include_path .:/usr/share/php:/usr/share/pear .:/usr/share/php:/usr/share/pear
Sto usando php5
e ho anche provato a installare il pacchetto php-pear
, ancora ottengo lo stesso errore.
Non capisco che cosa c'è che non va qui. Per favore qualcuno può puntare in una direzione giusta.
Nota: non ho installato PHP5 utilizzando sudo apt-get install php5
. Ho scaricato i pacchetti PHP5 utilizzando Keryx applicazione.
Soluzione
Sembra non è stato installato il pacchetto DB, provare a prompt dei comandi, fare
pear list
Se non è installato nessun pacchetto di DB
, è possibile installato con
pear install DB