【发布时间】:2017-03-03 02:20:42
【问题描述】:
我已经扩展了 PHP 的 mysqli 类,它工作正常。但是如何让它在查询时返回一个自定义结果对象(或用于插入/更新/删除等的布尔值)?
namespace MyApp;
class MySQLi extends \mysqli {
public function query($query, $resultmode = null) {
// This needs to return a MySQLiResult or a boolean
}
}
class MySQLiResult extends \mysqli_result {
}
这样做我可以返回一个 MySQLiResult 对象,但我不知道如何为非基于选择的查询返回一个布尔值:
public function query($query, $resultmode = null) {
$this->real_query($query);
return new MySQLiResult($this);
}
更新:
这是我最终使用的:
class MySQLi extends \mysqli {
public function query($query, $resultmode = null) {
$result = parent::query($query, $resultmode);
return is_bool($result) ? $result : new MySQLiResult($result);
}
}
class MySQLiResult {
private $result;
public function __construct(mysqli_result $result) {
$this->result = $result;
}
public function __call($name, $arguments) {
return call_user_func_array(array($this->result, $name), $arguments);
}
public function __set($name, $value) {
$this->result->$name = $value;
}
public function __get($name) {
return $this->result->$name;
}
}
【问题讨论】: