摘要: LINQ 與 IEnumerable 介面
LINQ 與 IEnumerable 介面
文/黃忠成
  架 構上而言,只要是實作IEnumerable<T>介面的物件,皆可做為LINQ To Objects的資料來源,那如果只是實作了IEnumerable介面的物件呢?以.NET Framework 1.1時我們常用的ArrayList來說,是否也能做為LINQ To Objects的資料來源呢?答案是肯定的,透過LINQ To Objects所提供的Cast或是OfType函式,我們可以輕易的將ArrayList轉變為實作IEnumerable<T>介面的物 件,進而將IEnumerable介面的物件運用於LINQ To Objects中。
static void Main(string[] args) {             ArrayList al = new ArrayList();             al.Add("1");             al.Add("2");             var item = (from s1 in al.Cast<string>()                          where s1 == "2" select s1).First();             Console.WriteLine(item);             Console.ReadLine(); }  | 
此手法也適用於實作IEnumerable介面的SqlDataReader物件。
public static List<string> GetTables(SqlConnection conn) {             using (SqlCommand cmd = conn.CreateCommand())             {                 if (conn.State == ConnectionState.Closed)                     conn.Open();                 cmd.CommandText = "exec sp_tables";                 using (SqlDataReader reader =                      cmd.ExecuteReader(CommandBehavior.CloseConnection))                 {                     return (from s1 in reader.OfType<IDataRecord>()                             where s1.GetString(s1.GetOrdinal("TABLE_TYPE")) == "TABLE"                             select s1.GetString(s1.GetOrdinal("TABLE_NAME"))).ToList();                 }             } }  | 
重點是你必須了解,該Enumerable中內含的元素型別就是了。
註: 當然,比起使用LINQ,直接於CommandText中下達【exec sp_tables @table_type = "'table'"】還是比較方便的,本例只是為了演示如何將SqlDataReader等類僅實作IEnumerable但未實作IEnumerable<T>介面的物件運用於LINQ上。