0

mysqli に問題があります。内で使用しようとするとエラーが発生しphpますが、一部でクエリを実行するdatabase applicationと完全に機能しました。それは私にエラーを与えます

SET @rank=0; SELECT (@rank := @rank+1)

正しく実行できますmysql yog。どうすればそれを機能させることができますか?

コードは次のとおりです。

function get_rank($branch,$cat){
    global $connection;
    $result = array();
    $rank = 0;
    if ($statement = $connection->prepare("SET @rank=0; SELECT (@rank := @rank+1) AS rank, a.branch_code_id, SUM(b.amount), c.category FROM sales_add_h AS a INNER JOIN sales_add_i AS b ON a.id = b.sales_h_id INNER JOIN control_panel_item_create AS c ON b.item_code_id = c.id WHERE a.branch_code_id = ? AND c.category = ? GROUP BY c.category, a.branch_code_id, b.amount ORDER BY SUM(b.amount) DESC")) {        
       $statement->bind_param("is",$branch,$cat); 
       $statement->execute();
       $statement->bind_result($a,$b,$c,$d);
        while ($row = $statement->fetch()) {
            array_push($result,array($a,$b,$c,$d));
        }     
        $statement->close();
    } else  {
        printf("Errormessage: %s\n", $connection->error);
        echo " error in SQL Statement.";
    }
    return $result;
}
4

2 に答える 2