CRecordset::FlushResultSet
Recupera o próximo conjunto de resultados de uma consulta predefinida (procedimento armazenado), se houver vários conjuntos de resultados.
BOOL FlushResultSet( );
Valor de retorno
Diferente de zero se não houver mais conjuntos de resultados a serem recuperados; caso contrário, 0.
Comentários
Você deve telefonar FlushResultSet somente quando você estiver totalmente concluída com o cursor no corrente conjunto de resultados. Observe que, ao recuperar o próximo resultado definido pelo telefonar ndo FlushResultSet, o cursor inválido em que conjunto de resultados; você deve telefonar o MoveNext função de membro depois telefonar ndo FlushResultSet.
Se uma consulta predefinida usa um parâmetro de saída ou parâmetros de entrada/saída, você deverá telefonar FlushResultSet até que ele retorne FALSE (o valor 0), para obter esses valores de parâmetro.
FlushResultSet chama a função de API do ODBC SQLMoreResults. If SQLMoreResults Retorna SQL_ERROR or SQL_INVALID_HANDLE, then FlushResultSet lançará uma exceção. Para obter mais informações sobre o SQLMoreResults, consulte o Windows SDK.
In Visual C++ 2005 o procedimento armazenado precisa ter limite campos se desejar telefonar FlushResultSet.
Exceções
Esse método pode lançar exceções do tipo CDBException *.
Exemplo
O código a seguir pressupõe que COutParamRecordset é um CRecordset-objeto derivado com base em uma consulta predefinida com um parâmetro de entrada e um parâmetro de saída e ter vários conjuntos de resultados. Observe a estrutura do DoFieldExchange substituir.
// 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();
Requisitos
Cabeçalho: afxdb.h