Tengo una consulta dinámica que devuelve alrededor de 590,000 registros. Funciona con éxito la primera vez, pero si lo vuelvo a ejecutar, sigo obteniendo un System.OutOfMemoryException
. ¿Cuáles son algunas de las razones por las que esto podría estar pasando?Excepción de tipo 'System.OutOfMemoryException' fue lanzado. ¿Por qué?
El error está ocurriendo aquí:
public static DataSet GetDataSet(string databaseName,string
storedProcedureName,params object[] parameters)
{
//Creates blank dataset
DataSet ds = null;
try
{
//Creates database
Database db = DatabaseFactory.CreateDatabase(databaseName);
//Creates command to execute
DbCommand dbCommand = db.GetStoredProcCommand(storedProcedureName);
dbCommand.CommandTimeout = COMMAND_TIMEOUT;
//Returns the list of SQL parameters associated with that stored proecdure
db.DiscoverParameters(dbCommand);
int i = 1;
//Loop through the list of parameters and set the values
foreach (object parameter in parameters)
{
dbCommand.Parameters[i++].Value = parameter;
}
//Retrieve dataset and set to ds
ds = db.ExecuteDataSet(dbCommand);
}
//Check for exceptions
catch (SqlException sqle)
{
throw sqle;
}
catch (Exception e)
{
throw e; // Error is thrown here.
}
//Returns dataset
return ds;
}
Aquí está el código se ejecuta en el botón de clic:
protected void btnSearchSBIDatabase_Click(object sender, EventArgs e)
{
LicenseSearch ls = new LicenseSearch();
DataTable dtSearchResults = new DataTable();
dtSearchResults = ls.Search();
Session["dtSearchResults"] = dtSearchResults;
Response.Redirect("~/FCCSearch/SearchResults.aspx");
}
else
lblResults.Visible = true;
}
¿Podemos ver el código? –
590K filas es un poco excesivo, ¿no crees? – StingyJack
¿No es el problema simplemente que está almacenando DataTable en la sesión y luego, al volver a consultar, tiene ambas variables de sesión y su DataTable original en la memoria? Por cierto, no llames a 'throw e;', llama a 'throw;' ya que de lo contrario tu rastro de pila dirá que el manejador 'catch' generó la excepción, cuando en realidad es el código que lo contiene. –