c# – 用SqlDataReader foreach?

前端之家收集整理的这篇文章主要介绍了c# – 用SqlDataReader foreach?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有如下代码: @H_404_2@sqlDataReader reader = getAddressQuery.sqlReader; while (reader.Read()) { foreach (Object ob in reader) { someText.InnerText = someText.InnerText + " " + ob.ToString(); } }

foreach循环中的代码不执行.但是,我可以这样做:

@H_404_2@sqlDataReader reader = getAddressQuery.sqlReader; while (reader.Read()) { someText.InnerText = reader[0].ToString(); }

哪个工作.

显然,我可以使用常规的循环而不是foreach循环来实现相同的结果,但是我认为foreach语法更清晰,所以我可以使用它.

这里出了什么问题? c#中的foreach循环不像更高级语言那么灵活吗?

解决方法

像下面这样的东西请注意,IDataReader来自IDataRecord,它显示用于处理当前行的成员: @H_404_2@IEnumerable<IDataRecord> GetFromReader(IDataReader reader) { while(reader.Read()) yield return reader; } foreach(IDataRecord record in GetFromReader(reader)) { ... process it ... }

或者甚至类似于以下内容,从读者获取强类型实体对象的枚举或列表:

@H_404_2@IEnumerable<T> GetFromReader<T>(IDataReader reader,Func<IDataRecord,T> processRecord) { while(reader.Read()) yield return processRecord(reader); } MyType GetMyTypeFromRecord(IDataRecord record) { MyType myType = new MyType(); myType.SomeProperty = record[0]; ... return myType; } IList<MyType> myResult = GetFromReader(reader,GetMyTypeFromRecord).ToList();

UPDATE响应Caleb Bell的评论.

我同意Enumerate是一个更好的名字.

事实上,在我的个人“常用”库中,我已经通过IDataReader上的扩展方法替换了上述内容

@H_404_2@public static IEnumerable<IDataRecord> Enumerate(this IDataReader reader) { while (reader.Read()) { yield return reader; } }

调用者可以使用以下方式获取强类型的对象:

@H_404_2@reader.Enumerate.Select(r => GetMyTypeFromRecord(r))

猜你在找的C#相关文章