sql >> Base de Datos >  >> RDS >> Sqlserver

Rellenar ArrayList a partir del conjunto de resultados del procedimiento almacenado

Lo que debes hacer es invocar ExecuteReader() en ese cmd objeto, así:

public static IEnumerable<int> GetAllVendors()
{
    using (var cmd = Data.GetCommand(Configuration.DatabaseOwnerPrefix + ".GetAllInformationAndHelpVendorIds", Connections.MyDbConnection))
    {
        using (var reader = cmd.ExecuteReader())
        {
            while (reader.Read())
            {
                yield return reader.GetInt32(0);
            }
        }
    }
}

Esto supone que el SQL devolverá una tabla cuya primera columna (identificada por el índice 0 al método GetInt32() ) será el ID que está buscando. Si el SQL devuelve los ID en otra columna, simplemente ajuste el índice a la columna en la que espera encontrarlos.

Esta solución también espera que la conexión del comando ya esté abierta. Si no es así, puede hacer cmd.Connection.Open() justo antes de cmd.ExecuteReader() .