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()
のコメントセクションでいくつかの解決策を見つけることができます

PDOがすぐに使用できるのに、mysqliがこの不要な面倒なものをすべて必要とする理由がわかりません。すぐにできるコードを次のコードと比較してください。

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