【发布时间】:2011-09-11 23:22:46
【问题描述】:
我对 OOP 风格的 PHP 非常陌生,我也在尝试实现 PDO。我在网上找到了一个处理数据库连接的不错的小类,但是我不知道如何从另一个类访问它。代码如下:
class PDO_DBConnect {
static $db ;
private $dbh ;
private function PDO_DBConnect () {
$db_type = 'mysql'; //ex) mysql, postgresql, oracle
$db_name = 'postGal';
$user = 'user' ;
$password = 'pass' ;
$host = 'localhost' ;
try {
$dsn = "$db_type:host=$host;dbname=$db_name";
$this->dbh = new PDO ( $dsn, $user, $password);
$this->dbh->setAttribute(PDO::ATTR_PERSISTENT, true);
$this->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch ( PDOException $e ) {
print "Error!: " . $e->getMessage () . "\n" ;
die () ;
}
}
public static function getInstance ( ) {
if (! isset ( PDO_DBConnect::$db )) {
PDO_DBConnect::$db = new PDO_DBConnect ( ) ;
}
return PDO_DBConnect::$db->dbh;
}
}
$db_handle = PDO_DBConnect::getInstance();
class Person
{
function __construct()
{
$STMT = $db_handle->prepare("SELECT title FROM posts WHERE id = ? AND author = ? LIMIT 20");
$STMT->execute(array('24', 'Michael'));
while ($result = $STMT->fetchObject())
{
echo $result->title;
echo "<br />";
}
}
}
如何访问我的 Person 类中的 $db_handle 变量?我必须在 Person 类中实例化变量吗?如果是这样,这是否意味着我将始终将其称为 $this->db_handle ?我希望避免这种情况。 (我对类的变量作用域仍然只有非常基本的了解)
【问题讨论】:
-
你为什么使用 PHP5 OO 构造,而不是 PHP4 时代的同名构造函数?请考虑改用
__construct。 -
我不认为他编写了 PDO_DBConnect 类,因为他提到他“找到了它”。