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;
}