Правильный способ выполнения вложенных SQL-запросов с использованием SQL-сервера и PHP - PullRequest
1 голос
/ 22 марта 2012

У меня есть вложенный запрос, который, когда я выполняю в SQL Server 2008 Management Studio, он работает отлично, он выводит два результата, но когда я пытаюсь сделать это в PHP, я получаю сообщение об ошибке и думаю, что это связано сВывод PHP.

Итак, вот запрос на SQL-сервере, который работает, но я думаю, что это неправильно:

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

Я получаю ошибку при выполнении этого запроса:

Error in query preparation/execution. Array ( [0] => Array ( [0] => 01000 [SQLSTATE] => 01000 [1] => 16954 [code] => 16954 [2] => [Microsoft][SQL Server Native Client 10.0][SQL Server]Executing SQL directly; no cursor. [message] => [Microsoft][SQL Server Native Client 10.0][SQL Server]Executing SQL directly; no cursor. ) [1] => Array ( [0] => 01S02 [SQLSTATE] => 01S02 [1] => 0 [code] => 0 [2] => [Microsoft][SQL Server Native Client 10.0]Cursor type changed [message] => [Microsoft][SQL Server Native Client 10.0]Cursor type changed ) ) 

Я изучал вложенные запросы, а также просматривал руководство по PHP, пытаясь узнать больше о том, как выводить результаты.просто так, потому что это работает в SQL Server Management Studio, не означает, что синтаксис правильный.Любой совет приветствуется.

1 Ответ

4 голосов
/ 22 марта 2012

На самом деле это два совершенно разных запроса:

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

и

(select * 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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...