[英]How to pass sql query with sql variables in php
I want to pass following sql query in php 我想在php中传递以下sql查询
SET @rank=0; SELECT @rank:=@rank+1 AS rank, `percentage_obtained` FROM `result` ORDER BY percentage_obtained DESC
As here 就像这里
mysql_query('SET @rank=0; SELECT @rank:=@rank+1 AS rank, `percentage_obtained` FROM `result` ORDER BY percentage_obtained DESC') or die(mysql_error());
But it throws following error 但它引发以下错误
You have an error in your SQL syntax;
您的SQL语法有误; check the manual that corresponds to your MySQL server version for the right syntax to use near 'SELECT
@rank
:=@rank
+1 AS rank,percentage_obtained
FROMresult
' at line 1检查对应于你的MySQL服务器版本使用附近的正确语法手册“SELECT
@rank
:=@rank
+1 AS级别,percentage_obtained
FROMresult
”在1号线
However it works when I run the query directly inside the database. 但是,当我直接在数据库中运行查询时,它可以工作。 Please assist.
请协助。
mysql_query() doesn't support multiple queries, so you need to separate them. mysql_query()不支持多个查询,因此您需要将它们分开。 Also you can use mysqli_multi_query - but note, that you need mysqli instead of mysql
您也可以使用mysqli_multi_query-但请注意,您需要mysqli而不是mysql
So 所以
mysql_query('SET @rank=0') or die(mysql_error());
mysql_query('SELECT @rank:=@rank+1 AS rank, `percentage_obtained` FROM `result` ORDER BY percentage_obtained DESC') or die(mysql_error());
should handle this 应该处理这个
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.