Поделиться через


Практическое руководство. Отключение множественных активных результирующих наборов (функция MARS)

Скачать драйвер PHP

Если необходимо подключиться к источнику данных SQL Server, который не включает множественные активные результирующие наборы (MARS), можно использовать параметр подключения MultipleActiveResultSets для отключения или включения функции MARS.

Процедура

Отключение поддержки функции MARS

  • Используйте следующий параметр подключения:

    'MultipleActiveResultSets'=>false  
    

    Если приложение пытается выполнить запрос для подключения с открытым активным результирующим набором, при второй попытке выполнения запроса возвращаются следующие сведения об ошибке:

    Подключение не может обработать эту операцию, поскольку отсутствует инструкция с ожидающими результатами. Чтобы сделать подключение доступным для других запросов, извлеките все результаты, отмените инструкцию или освободите ее. Дополнительные сведения о параметре подключения MultipleActiveResultSets см. в статье Connection Options.

Пример SQLSRV

В следующем примере показано, как отключить поддержку MARS с помощью драйвера SQLSRV драйверов Майкрософт для PHP для SQL Server.

<?php  
/* Connect to the local server using Windows Authentication and  
specify the AdventureWorks database as the database in use. */  
$serverName = "MyServer";  
$connectionInfo = array( "Database"=>"AdventureWorks", 'MultipleActiveResultSets'=> false);  
$conn = sqlsrv_connect( $serverName, $connectionInfo);  
if( $conn === false )  
{  
   echo "Could not connect.\n";  
   die( print_r( sqlsrv_errors(), true));  
}  
  
sqlsrv_close( $conn);  
?>  

Пример PDO_SQLSRV

В следующем примере показано, как отключить поддержку MARS, используя драйвер PDO_SQLSRV драйверов Майкрософт для PHP для SQL Server.

<?php  
// Connect to the local server using Windows Authentication and AdventureWorks database  
$serverName = "(local)";   
$database = "AdventureWorks";  
  
try {  
   $conn = new PDO(" sqlsrv:server=$serverName ; Database=$database ; MultipleActiveResultSets=false ", NULL, NULL);   
   $conn->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );   
}  
  
catch( PDOException $e ) {  
   die( "Error connecting to SQL Server" );   
}  
  
$conn = null;   
?>  

См. также

Подключение к серверу