Mysql嵌套查询麻烦

时间:2012-10-05 19:36:19

标签: php mysql

我用嵌套的select语句创建了一个mysql seect语句。现在我的mysql技能(或缺乏)非常有限。下面是我写的代码。我得到空白结果或警告。 mysql_fetch_Array错误。现在我正在收到一条错误,上面写着“子查询返回超过1行”任何人都可以指出我正确的方向如何开始解决这个问题。谢谢你的帮助。

 <?php
session_start();

$memberId = $_GET['id'];

$loggedId = $_SESSION['id'];

include('../connect_DB.php');

$sql = 'SELECT bins.tag_Id, tagging_Info.plant_Id, tagging_Info.photo_Id FROM bins inner join tagging_Info on bins.tag_Id = tagging_Info.tag_Id inner join collections on collections.id = bins.collection_Id WHERE collections.member_Id ='.$memberId.' and collections.id=(SELECT id FROM collections where member_Id='.$memberId.')'; 

$result = mysql_query($sql) or die(mysql_error());
while($row = mysql_fetch_array($result)) {


   $collection = "Success"; // test to see if working

}
echo $collection;

?>

1 个答案:

答案 0 :(得分:2)

您是否尝试仅执行子查询以查看实际返回的记录数并确保$ memberId实际设置?

用户拥有多个集合是有意义的,因此您应该调整主查询以在子查询结果上使用IN而不是=。