C #: вернуть IEnumerable, когда поле не равно нулю? - PullRequest
1 голос
/ 04 мая 2011
public IEnumerable GetAddress()
{
     DataSet ds = DataOps.GetDataSet(string.Format(" select * from Students"));
     DataTable dt = ds.Tables[0];
     // What goes here?
}

Мне нужно использовать методы IEnumerable

Как я могу вернуть перечисление DataRows, содержащих всех студентов, которые имеют только адреса?

Ответы [ 3 ]

3 голосов
/ 04 мая 2011

Я не знаю, как выглядит ваш ученический класс, но вот макет

    private IEnumerable<Student> GetAddress()
        {
            DataSet ds = DataOps.GetDataSet(string.Format(" select * from Students Where NOT NULL [address]"));
            DataTable dt = ds.Tables[0];


            foreach (DataRow row in dt.Rows)
            {
                yield return new Student   
                                      {                                        
                                          StudentName = row["StudentName "].ToString(),
                                          Address= row["Address"].ToString()
                                      };
            }

        }

Это должно дать вам представление о том, куда идти дальше.

1 голос
/ 04 мая 2011

Я думаю, что вы ищете

DataRow[] dr = ds.Tables[0].Select("Address NOT NULL"); // you want filtering on address column
    foreach (DataRow row in dr)
    {

    }
0 голосов
/ 04 мая 2011

IEnumerable - это просто какой-то абстрактный список, через который вы можете перебирать - есть много способов вернуть экземпляр IEnumerable, например:

  • Использование конструкции yield return (только .Net 4.0)
  • Возвращая List<T>, или массив, или любой другой класс, который уже реализует IEnumerable,

Например:

public IEnumerable GetAddress()
{
    DataSet ds = DataOps.GetDataSet(string.Format(" select * from Students"));
    DataTable dt = ds.Tables[0];

    // The chances are that instead of string you will need a struct or a class
    List<string> retVal = new List<string>();
    foreach (DataRow row in dt)
    {
        // This will obviously depend on the table and return type
        retVal.Add((string)row["mycol"]);
    }
}

Кроме того, в зависимости от возвращаемого типа вы, вероятно, захотите вместо него вернуть IEnumerable<T>, так как он безопасен для потоков.

...