LINQ 與 IEnumerable 介面

本文介绍如何将仅实现IEnumerable接口的对象,如ArrayList或SqlDataReader,转换为适用于LINQ查询的形式。通过使用Cast或OfType方法,这些对象可以作为LINQ To Objects的数据源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 
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上。
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值