Aracılığıyla paylaş


CRecordset::FlushResultSet

Birden çok sonuç kümeleri (saklı yordam), önceden tanımlanmış bir sorgu sonraki sonuç kümesini alır.

BOOL FlushResultSet( );

Dönüş Değeri

Daha fazla sonuç kümeleri alınması, sıfır olmayan; Aksi halde 0.

Notlar

Çağırması gerekir FlushResultSet yalnızca tamamen geçerli sonuç kümesi imleç bittikten.Çağırarak sonraki sonuç almak dikkat FlushResultSet, imlecinizi; Bu sonuç kümesi üzerinde geçerli değil çağırması gerekir MoveNext arama sonra üye işlevi FlushResultSet.

Önceden tanımlanmış bir sorgu çıktı parametresi veya giriş/çıkış parametreleri kullanıyorsa, çağırması gerekir FlushResultSet verdiği kadar FALSE (Bu parametre değerlerini sağlamak için değer 0).

FlushResultSetodbc API işlevini çağırır SQLMoreResults.SQLMoreResults Döndüren SQL_ERROR veya SQL_INVALID_HANDLE, sonra FlushResultSet bir istisna atar.Hakkında daha fazla bilgi için SQLMoreResults, bkz: Windows SDK.

Saklı yordamınız aramak istiyorsanız, alanları ilişkili gereken FlushResultSet.

Özel Durumlar

Bu yöntem türü istisnalar atabilirsiniz CDBException*.

Örnek

Aşağıdaki kod varsayar COutParamRecordset olan bir CRecordset-türetilen nesne bir girdi parametresini ve bir çıkış parametresi ile önceden tanımlanmış bir sorguyu temel ve birden çok sonuç kümesi olması.Yapısıyla dikkat DoFieldExchange geçersiz kılar.

// 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();

Gereksinimler

Başlık: afxdb.h

Ayrıca bkz.

Başvuru

CRecordset sınıfı

Hiyerarşi grafik

CFieldExchange::SetFieldType