使用SQL server和PHP执行嵌套SQL查询的正确方法

使用SQL server和PHP执行嵌套SQL查询的正确方法,php,sql,sql-server-2008,Php,Sql,Sql Server 2008,我有一个嵌套查询,当我在SQLServer2008ManagementStudio中执行时,它工作得很好,它输出两个结果,但当我尝试在PHP中执行此操作时,我收到一个错误,我认为这与PHP输出有关 下面是SQL server中的查询,它可以工作,但我认为这是不对的: select * from product_catalogue where catalogueid =(select catalogueid from products where productid = 1) (select *

我有一个嵌套查询,当我在SQLServer2008ManagementStudio中执行时,它工作得很好,它输出两个结果,但当我尝试在PHP中执行此操作时,我收到一个错误,我认为这与PHP输出有关

下面是SQL server中的查询,它可以工作,但我认为这是不对的:

select * from product_catalogue where catalogueid =(select catalogueid from products where productid = 1)  (select * from products where productid = 1)
以下是PHP中的完整查询:

        $query3 = "select * from product_catalogue where catalogueid =(select catalogueid from products where productid = '" . $productid . "')  (select * from products where productid = '" . $productid . "')";                      

    $result3 = sqlsrv_query( $conn, $query3, array(), array( "Scrollable" => SQLSRV_CURSOR_KEYSET ));

    if( $result3 === false)
    {
         echo "Error in query preparation/execution.\n";
         die( print_r( sqlsrv_errors(), true));
    }


        while( $obj = sqlsrv_fetch_object( $result3)) 
                    {

                        $prod_image = $obj->picturem;
                        $prod_id = $obj->catalogueID;
                        $prod_description = $obj->description;
                        $prod_price = $obj->product_price;
                        echo "<p>$prod_id" ;
                        echo "<br/>$prod_description" ;
                        echo "<br/>&pound;$prod_price"; 
                        echo "<br/><br/><img src='$prod_image'  width='200' height='400'/>"; 
                        echo "<br/><br/>";
                        }

我一直在研究嵌套查询,并阅读PHP手册,试图了解更多关于如何输出结果的信息,我只是觉得,因为它在SQLServerManagementStudio中工作,并不意味着语法是正确的。感谢您的建议。

这实际上是两个完全不同的查询:

select * from product_catalogue where catalogueid =(select catalogueid from products where productid = 1)  

执行所需操作的最简单方法是在单个查询中联接表,类似于:

select c.catalogueID, 
       c.product_name, 
       c.product_price, 
       c.description, 
       p.productID, 
       p.picturem, 
       p.picturew
from product p
join product_catalogue c on c.catalogueid = p.catalogueid
where p.productid = 1

这实际上是两个完全不同的查询:

select * from product_catalogue where catalogueid =(select catalogueid from products where productid = 1)  

执行所需操作的最简单方法是在单个查询中联接表,类似于:

select c.catalogueID, 
       c.product_name, 
       c.product_price, 
       c.description, 
       p.productID, 
       p.picturem, 
       p.picturew
from product p
join product_catalogue c on c.catalogueid = p.catalogueid
where p.productid = 1

是的,我觉得这就是问题所在,我实际上在做两个查询,并希望PHP将其作为一个查询来处理。不久前有人告诉我,我记不起何时何地了,但如果它在SQL management studio中工作,它应该在其他任何地方工作。我将尝试使用联接,谢谢。我一直在研究联接,但不知道如何正确执行此操作,因为我想从两个表中全部选择,这可能吗?谢谢@deucalion0:能否列出要从每个表返回的列?我询问的原因是,如果不同的表具有相同的列名,SQL查询通常需要不同的列别名(否则将返回错误)。另外,最好只选择所需的列,而不是所有查询表上的所有列。这是个好主意,只选择所需的列,我需要更好的习惯!这两个表和所需的列是:表:产品目录列:目录ID、产品名称、产品价格、说明表:产品列:产品ID、图片EM、图片EW非常感谢您的帮助!非常感谢,这正好说明了它是如何工作的!我真的很感谢你的时间和努力!是的,我觉得这就是问题所在,我实际上在做两个查询,并希望PHP将其作为一个查询来处理。不久前有人告诉我,我记不起何时何地了,但如果它在SQL management studio中工作,它应该在其他任何地方工作。我将尝试使用联接,谢谢。我一直在研究联接,但不知道如何正确执行此操作,因为我想从两个表中全部选择,这可能吗?谢谢@deucalion0:能否列出要从每个表返回的列?我询问的原因是,如果不同的表具有相同的列名,SQL查询通常需要不同的列别名(否则将返回错误)。另外,最好只选择所需的列,而不是所有查询表上的所有列。这是个好主意,只选择所需的列,我需要更好的习惯!这两个表和所需的列是:表:产品目录列:目录ID、产品名称、产品价格、说明表:产品列:产品ID、图片EM、图片EW非常感谢您的帮助!非常感谢,这正好说明了它是如何工作的!我真的很感谢你的时间和努力!