LINQ操作DataTable出现指定的转换无效问题怎么解决
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要讲解了"LINQ操作DataTable出现指定的转换无效问题怎么解决",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"LINQ操作DataTa
千家信息网最后更新 2025年11月13日LINQ操作DataTable出现指定的转换无效问题怎么解决
这篇文章主要讲解了"LINQ操作DataTable出现指定的转换无效问题怎么解决",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"LINQ操作DataTable出现指定的转换无效问题怎么解决"吧!
代码
public static IEnumerable getEnumerable() { DataTable dt = getDatatable(); try { var query = from q in dt.AsEnumerable() where q.Field("IPLocation") == "纯真网络 2008年6月20日IP数据" select new { IPid = q.Field("IPid"), IPFrom = q.Field("IPFrom"), IPTo = q.Field("IPTo"), IPCity = q.Field("IPCity"), IPToNumber = q.Field("IPToNumber"), IPFromNumber = q.Field("IPFromNumber") }; return query; } catch { return null; } } 然后我在***做数据源绑定的时候,总是报System.InvalidCastException: 指定的转换无效的错误,无论用Gridview的自动生成列,还是Reapter的手动添加列,都有问题,***我查出生成的结果集就含有异常的存在,也就说再取结果集的时候,要慎重用如下写法:
IPid = q.Field("IPid"), IPFrom = q.Field ("IPFrom"), IPTo = q.Field ("IPTo"), IPCity = q.Field ("IPCity"), IPToNumber = q.Field ("IPToNumber"), IPFromNumber = q.Field ("IPFromNumber")
我后来尝试了另一种写法:
IPid = q["IPid"].ToString(), IPFrom = q["IPFrom"].ToString(), IPTo = q["IPTo"].ToString(), IPLocation = q["IPLocation"].ToString(), IPCity = q["IPCity"].ToString(), IPToNumber = q["IPToNumber"].ToString(), IPFromNumber = q["IPFromNumber"].ToString()
一开始我调试也还是报System.InvalidCastException: 指定的转换无效这个错误,我调试了一段时间,也还是有问题,我在想是不是数据绑定控件的问题,后来我将原来的Gridview自动生成列换成了手动输入列:
代码
| ID | IPFrom | IPTo | IPLocation | City | IPToNumber | IPFromNumber |
|---|---|---|---|---|---|---|
| <%#Eval("IPid")%> | <%#Eval("IPFrom")%> | <%#Eval("IPTo")%> | <%#Eval("IPLocation")%> | <%#Eval("IPCity") %> | <%#Eval("IPToNumber")%> | <%#Eval("IPFromNumber")%> |
后来问题就解决了,我现在也不知道这个问题什么原因,为什么不支持自动产生列呢(等待高手帮忙解决)?
知道问题的所在了,然后就可以随心的处理DataTable里面的数据了,如下面一个简单的小例子:
代码
public static IEnumerable getEnumerable() { DataTable dt = getDatatable(); try { var query = from q in dt.AsEnumerable() orderby long.Parse(q["IPid"].ToString()) descending where q["IPid"].ToString() == "345058" select new { IPid = q["IPid"].ToString(), IPFrom = q["IPFrom"].ToString(), IPTo = q["IPTo"].ToString(), IPLocation = q["IPLocation"].ToString(), IPCity = q["IPCity"].ToString(), IPToNumber = q["IPToNumber"].ToString(), IPFromNumber = q["IPFromNumber"].ToString() }; return query; //List list = new List(); //foreach (var q in query) //{ //IPInfo model = new IPInfo(); //model.IPCity = q.IPCity; //model.IPFrom = q.IPFrom; //model.IPFromNumber = q.IPFromNumber; //model.IPid = long.Parse(q.IPid); //model.IPLocation = q.IPLocation; //model.IPTo = q.IPTo; //model.IPToNumber = q.IPToNumber; //list.Add(model); //} //return list; } catch { return null; } } 感谢各位的阅读,以上就是"LINQ操作DataTable出现指定的转换无效问题怎么解决"的内容了,经过本文的学习后,相信大家对LINQ操作DataTable出现指定的转换无效问题怎么解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
问题
数据
代码
还是
学习
生成
内容
写法
手动
时候
结果
自动生成
错误
纯真
例子
原因
就是
思路
情况
所在
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全专业吃青春饭吗
经济会议关于网络安全
死亡跑酷的服务器
网络安全工作基本原则
连不上代理服务器
hymenoptera数据库
软件测试好还是软件开发好
软件开发干了好多年
我的世界僵尸枪战服务器
山西麻将软件开发哪家强
数据库强实体集和弱实体集
聊城党员教育软件开发系统
高三信息技术学业水平测试数据库
lra数据库
管理公司服务器网络的
微信启用服务器配置
分布式存储服务器安全
etl数据库无法输出
服务器可以用哪些安全
win10系统管理服务器
学生网络安全事故
在公司怎么从数据库中提取数据
重庆网络安全处罚裁量基准
比特币与软件开发的应用
南充市软件开发培训
网络安全3 号令
对软件开发工具的展望
广东服务器机柜生产公司
分布式存储服务器安全
网络安全性低怎么回事