INFORMAZIONI: Risultati troncati durante la chiamata IDirectorySearch::GetNextRow

Il presente articolo è stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell’utente. Tuttavia, un articolo tradotto in modo automatico non è sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, più o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non è la sua. Microsoft non è responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell’utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.

Clicca qui per visualizzare la versione originale in inglese dell’articolo: 325189
Questo articolo è stato archiviato. L’articolo, quindi, viene offerto “così come è” e non verrà più aggiornato.
Sommario
La documentazione di MSDN sulla funzione IDirectorySearch::GetNextRow è incompleta. La descrizione del valore restituito S_ADS_NOMORE_ROWS è false. Questo codice non significa "riga corrente è l'ultima riga e rimane invariato per". Al contrario, la descrizione deve indicare "per ora, la riga corrente è l'ultima riga", e se si desidera sapere se questo è effettivamente l'ultima riga, è necessario chiamare ADsGetLastError. "

Per ogni operazione non riuscita, ADSI imposta un codice di errore, è possibile eseguire query utilizzando ADsGetLastError. Se questo errore esteso non è gestito dallo sviluppatore, un'operazione di ricerca potrebbe concludere in modo anomalo prima dell'elaborazione di tutte le righe. Per ulteriori informazioni sul service pack più recente per Microsoft Windows 2000, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
260910Come ottenere Windows 2000 Service Pack più recente
Informazioni
Quando la funzione di IDirectorySearch::GetNextRow restituisce S_ADS_NOMORE_ROWS, non può avere recuperati tutti i dati dal server. In alcuni casi, S_ADS_NOMORE_ROWS viene restituito dalla funzione il metodo GetNextRow , in quando il server è stato Impossibile trovare una voce corrispondente ai criteri di ricerca entro un limite di tempo predefinito di due minuti. Questo limite di tempo due minuti è definito per mezzo di un criterio LDAP. Per ulteriori informazioni sui criteri LDAP, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito:
315071Procedura: Visualizzare e impostare criteri LDAP utilizzando Ntdsutil.exe
Se il server supera il limite di tempo di due minuti, viene restituito un cookie LDAP nella risposta in modo che è possibile riavviare la ricerca in cui è stata interrotta. Ricerche inefficiente e sistemi con caricati elevato è possono che il server di superare il limite di tempo. Quando il server non trova un indice efficiente per la ricerca, il server abbia applicare il filtro a ogni oggetto nella directory, in questo caso può eseguire tutte le voci e non trova una corrispondenza nel limite di tempo due minuti.

Di conseguenza, quando viene restituita S_ADS_NOMORE_ROWS, ADSI imposta anche un codice di errore, è possibile eseguire query utilizzando ADsGetLastError funzione. Se ADsGetLastError restituisce ERROR_MORE_DATA, significa che il server non è stata completata la query e se deve chiamare il metodo GetNextRow nuovamente.

The Platform SDK sample file, DsSrch, can be modified to handle this search method as shown in the following code sample:
"MAIN.CXX" file//------------------------------------------------------------------// //  Function:   Q325189_GetNextRow// //  Synopsis:// //------------------------------------------------------------------HRESULT Q325189_GetNextRow(IDirectorySearch *pDSSearch, ADS_SEARCH_HANDLE hSearchHandle){	HRESULT hr = S_OK;	DWORD dwADsExtError = ERROR_SUCCESS;	WCHAR szErrorBuf[512];	WCHAR szNameBuf[128];	do	{		// Clear ADSI extended error		dwADsExtError = ERROR_SUCCESS;		ADsSetLastError(ERROR_SUCCESS, NULL, NULL);		// Next row		hr = pDSSearch->GetNextRow(hSearchHandle);		BAIL_ON_FAILURE(hr);		// Check ADSI extend error if we got S_ADS_NOMORE_ROWS		if (S_ADS_NOMORE_ROWS == hr)		{			hr = ADsGetLastError(&dwADsExtError, szErrorBuf, 512, szNameBuf, 128);			BAIL_ON_FAILURE(hr);			if (ERROR_MORE_DATA != dwADsExtError)				// All data received				return ERROR_NO_DATA;		}	} while (ERROR_MORE_DATA == dwADsExtError);	return ERROR_MORE_DATA;error:	return hr;}//------------------------------------------------------------------// //  Function:   main// //  Synopsis:// //------------------------------------------------------------------INT _CRTAPI1main(int argc, char * argv[]){...	// *** MODIFIED FOR Q325189 *** 	//hr = pDSSearch->GetNextRow(	//         hSearchHandle	//         );	//BAIL_ON_FAILURE(hr);	hr = Q325189_GetNextRow(pDSSearch, hSearchHandle); 	// *** EOM ***	// *** MODIFIED FOR Q325189 *** 	//while (hr != S_ADS_NOMORE_ROWS && nRows < dwMaxRows) {<BR/>         BAIL_ON_FAILURE(hr);	while (nRows < dwMaxRows) {	// *** EOM ***        nRows++;        if (dwNumberAttributes == -1) {            hr = pDSSearch->GetNextColumnName(                     hSearchHandle,                     &pszColumnName                     );            BAIL_ON_FAILURE(hr);            while (hr != S_ADS_NOMORE_COLUMNS) {                hr = pDSSearch->GetColumn(                         hSearchHandle,                         pszColumnName,                         &Column                         );                if (FAILED(hr)  && hr != E_ADS_COLUMN_NOT_SET)                    goto error;                if (SUCCEEDED(hr)) {                    PrintColumn(&Column, pszColumnName);                    pDSSearch->FreeColumn(&Column);                }                FreeADsMem(pszColumnName);                hr = pDSSearch->GetNextColumnName(                         hSearchHandle,                         &pszColumnName                         );                BAIL_ON_FAILURE(hr);            }            printf("\n");        }        else {            for (DWORD i=0; i<dwNumberAttributes; i++) {                hr = pDSSearch->GetColumn(                         hSearchHandle,                         pszAttrNames[i],                         &Column                         );                if (hr == E_ADS_COLUMN_NOT_SET)                    continue;                BAIL_ON_FAILURE(hr);                PrintColumn(&Column, pszAttrNames[i]);                pDSSearch->FreeColumn(&Column);            }        printf("\n");        }	// *** MODIFIED FOR Q325189 ***         //hr = pDSSearch->GetNextRow(        //         hSearchHandle        //         );        //BAIL_ON_FAILURE(hr);		hr = Q325189_GetNextRow(pDSSearch, hSearchHandle); 	// *** END OF MODIFICATION ***    }    wprintf (L"Total Rows: %d\n", nRows);...}				
Riferimenti
Per ulteriori informazioni, visitare i seguenti siti Web MSDN:
IDirectorySearch il metodo GetNextRow S_ADS_NOMORE_ROWS ERROR_MORE_DATA ADsGetLastError troncato

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 325189 - Ultima revisione: 01/17/2015 16:41:43 - Revisione: 4.0

Microsoft Active Directory Service Interfaces 2.5, Microsoft Active Directory Service Interfaces 2.5

  • kbnosurvey kbarchive kbmt kbdswadsi2003swept kbwin2ksp4fix kbinfo KB325189 KbMtit
Feedback