简体   繁体   English

如何在PHP中使用SQL变量传递SQL查询

[英]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 FROM result ' at line 1 检查对应于你的MySQL服务器版本使用附近的正确语法手册“SELECT @rank := @rank +1 AS级别, percentage_obtained FROM result ”在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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM