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


CRecordset::FlushResultSet

Возвращает следующий результирующий набор (предопределенного запроса хранимой процедуры), если несколько результирующих наборов.

BOOL FlushResultSet( );

Возвращаемое значение

Ненулевой если несколько результирующих наборов, который необходимо извлечь; в противном случае – значение 0.

Заметки

Следует вызывать только после завершения FlushResultSet полностью с курсором на текущем результирующем наборе. Обратите внимание, что при восстановлении следующий результирующий набор при вызове FlushResultSet, курсор недопустим в этом результирующем наборе; необходимо вызвать функцию-член MoveNext после вызова FlushResultSet.

Если предопределенный запрос использует параметр вывода или параметры ввода-вывода, необходимо вызвать метод FlushResultSet до тех пор, пока она не вернет FALSE (значение 0), чтобы получить эти значения параметров.

FlushResultSet вызывает api-функцию ODBC SQLMoreResults. Если SQLMoreResults возвращает SQL_ERROR или SQL_INVALID_HANDLE, то FlushResultSet вызовет исключение. Дополнительные сведения о SQLMoreResults см. в разделе Windows SDK.

Хранимой процедуре необходимо привязать поля если необходимо вызвать FlushResultSet.

Исключения

Этот метод может создавать исключения типа CDBException*.

Пример

В следующем примере кода предполагается, что CRecordsetCOutParamRecordset производный объект, основанный на стандартном запросе с входным параметром, и параметром вывода и иметь несколько результирующих наборов. Обратите внимание на структуру переопределения DoFieldExchange.

// DoFieldExchange override 
// 
// Only necessary to handle parameter bindings. 
// Don't use CRecordset-derived class with bound 
// fields unless all result sets have same schema 
// OR there is conditional binding code. 
void CCourses::DoFieldExchange(CFieldExchange* pFX)
{
   pFX->SetFieldType(CFieldExchange::outputParam);
   RFX_Long(pFX, _T("Param1"), m_nCountParam);
      // The "Param1" name here is a dummy name 
      // that is never used

   pFX->SetFieldType(CFieldExchange::inputParam);
   RFX_Text(pFX, _T("Param2"), m_strNameParam);
      // The "Param2" name here is a dummy name 
      // that is never used
}
// Assume db is an already open CDatabase object
CCourses rs(&m_dbCust);
rs.m_strNameParam = _T("History");

// Get the first result set 
// NOTE: SQL Server requires forwardOnly cursor  
//       type for multiple rowset returning stored  
//       procedures
rs.Open(CRecordset::forwardOnly, 
         _T("{? = CALL GetCourses( ? )}"), 
         CRecordset::readOnly);

// Loop through all the data in the first result set 
while (!rs.IsEOF())
{
   CString strFieldValue;
   for(short nIndex = 0; nIndex < rs.GetODBCFieldCount(); nIndex++)
   {
      rs.GetFieldValue(nIndex, strFieldValue);

      // TO DO: Use field value string.
   }
   rs.MoveNext();
}

// Retrieve other result sets... 
while(rs.FlushResultSet())
{
   // must call MoveNext because cursor is invalid
   rs.MoveNext();

   while (!rs.IsEOF())
   {
      CString strFieldValue;
      for(short nIndex = 0; nIndex < rs.GetODBCFieldCount(); nIndex++)
      {
         rs.GetFieldValue(nIndex, strFieldValue);

         // TO DO: Use field value string.
      }
      rs.MoveNext();
   }
}


// All result sets have been flushed. Cannot 
// use the cursor, but the output parameter, 
// m_nCountParam, has now been written. 
// Note that m_nCountParam is not valid until 
// CRecordset::FlushResultSet has returned FALSE, 
// indicating no more result sets will be returned. 

// TO DO: Use m_nCountParam 

// Cleanup
rs.Close();

Требования

заголовок: afxdb.h

См. также

Ссылки

Класс CRecordset

Диаграмма иерархии

CFieldExchange::SetFieldType