扩展mysqli_result

问题描述

| 我扩展了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;
    }

}
    

解决方法

        可能最简单的方法是将您的
MySQLiResult
类当作
mysqli_result
的装饰器。例如
class MySQLiResult
{
    private $result;

    public function __construct(\\mysqli_result $result)
    {
        $this->result = $result;
    }
}
然后,您可以将方法调用代理到内部结果,并在需要时进行修饰(添加功能)。     ,        Phil的回答是可以的,但是可以通过选中
mysqli::field_count
扩展MySQLi_Result。 查看ѭ7的文档   当使用mysqli_store_result()函数来确定查询是否应该在不知道查询性质的情况下产生非空结果集时,此函数很有用。 这正是我们所需要的。
public MySQL extends MySQLi
{
    public function query($query)
    {
        if ($this->real_query($query)) {
            if ($this->field_count > 0) {
                return new MySQL_Result($this);
            }
            return true;
        }

        throw new MySQL_Exception($this->error,$this->errno);
    }
}
现在,您可以从MySQLi_Result扩展结果类,并实现一些有用的接口,例如
SeekableIterator
,以便可以在结果集上使用
foreach
class MySQL_Result extends MySQLi_Result implements Countable,SeekableIterator,ArrayAccess
{
    ...
}