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上。
 
发布了102 篇原创文章 · 获赞 0 · 访问量 44万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章