1

我的查询类在客户端新服务器上不起作用,因为他们的服务器缺少 mysqlnd 驱动程序。我如何将方法转换为不使用 mysqlnd 并且不搞砸他们所有的类?

function query($query, $params=NULL) {
    if($params!=NULL) {
        $stmt = $this->mysqli->prepare($query); 
        //must turn $params into reference array to bind
        $ref = array();
        foreach ($params as $key => $value) {
            $ref[$key] = &$params[$key]; 
        }
        call_user_func_array(array($stmt,'bind_param'),$ref);
        $stmt->execute();
        $result = $stmt->get_result();
    } else {
        $result = $this->mysqli->query($query);
    }
    if($result){
        $rowArray = array();
        while ($myrow = $result->fetch_object()) {
            $rowArray[] = $myrow;
        }
        return $rowArray;
    }
    return false;
}
4

1 回答 1

2

使用非常相似的方法您可以在手册页call_user_func_array()
的评论部分中找到一些解决方案

我不知道为什么 mysqli 需要所有这些不必要的繁琐的东西,而 PDO 开箱即用。将您即将发布的代码与以下代码进行比较:

function query($query, $params=NULL) {
    $stmt = $this->pdo->prepare($query); 
    $stmt->execute($params);
    return $stmt->fetchAll();
}
于 2013-05-13T14:59:58.443 回答