题
我是 PHP oop 的新手。
我正在尝试创建类数据库并从中调用其他类。我的做法正确吗?
类数据库:
class database extends mysqli {
private $classes = array();
public function __construct() {
parent::__construct('localhost', 'root', 'password', 'database');
if (mysqli_connect_error()) {
$this->error(mysqli_connect_errno(), mysqli_connect_error());
}
}
public function __call($class, $args) {
if (!isset($this->classes[$class])) {
$class = 'db_'.$class;
$this->classes[$class] = new $class();
}
return $this->classes[$class];
}
private function error($eNo, $eMsg) {
die ('MySQL error: ('.$eNo.': '.$eMsg);
}
}
类 db_users:
class db_users extends database {
public function test() {
echo 'foo';
}
}
以及我如何使用它
$db = new database();
$db->users()->test();
这是正确的方式还是应该以其他方式完成?
谢谢。
解决方案
您可以那样做,这没什么错(我经常做类似的事情)。我唯一建议的是使用异常而不是死亡(这样您可以安全处理错误)...
protected function error($eNo, $eMsg, $extra = '') {
throw new Exception('MySQL error: ['.$eNo.'] '.$eMsg.': '.$extra);
}
另外,我建议还要超载查询方法
public function query($sql, $result_mode = MYSQLI_STORE_RESULT) {
$result = parent::query($sql, $result_mode);
if ($result === false) {
$this->error($this->errno, $this->errstr, $sql);
}
return $result;
}
我还建议在儿童课堂内存储$ db对象的副本。所以:
class db_users extends database {
protected $db = null;
public function __construct(Database $db) {
$this->db = $db;
}
public function test() {
echo 'foo';
}
}
然后,在__call中:
if (!isset($this->classes[$class])) {
$class = 'db_'.$class;
$this->classes[$class] = new $class($this);
}
其他提示
这种创建类的工厂风格没有什么问题。我会在其中放置一些异常处理。
我唯一关心的是在子类中扩展数据库。
所以我会修改如下:
public function __call($className, $args) {
if (!isset($this->classes[$class])) {
if(include_once('db_'.$class)) {
$class = 'db_'.$class;
$this->classes[$class] = new $class($this);
} else {
throw new Exception("Db class not found");
}
}
return $this->classes[$class];
}
用户类别为:
public class db_users {
private $db;
public __constructor($db) {
$this->db = $db;
}
public function test() {
return 'Foo';
}
}
不隶属于 StackOverflow