LINQ操作DataTable出现指定的转换无效问题怎么解决
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,这篇文章主要讲解了"LINQ操作DataTable出现指定的转换无效问题怎么解决",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"LINQ操作DataTa
千家信息网最后更新 2025年01月18日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; //Listlist = 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安全错误
数据库的锁怎样保障安全
网络安全罪是什么
软件sql数据库是什么软件
中国工业技术数据库
大部分数据库都遵循什么标准
服务器电源5v双输出
慧族软件开发
软件开发过程图
网络安全问答题小学生
锡山区软件开发服务电话
vps服务器 安全上网
重庆彭水生鲜配送软件开发
安徽服务器机柜加工云空间
华为服务器资料
服务器系统用光盘好装么
国家级二级数据库
数据库表怎样插入信息
昆明状元珂辰软件开发有限公司
如何学好网络安全技术论文
网络安全法 第五章
企业密信服务器fm888
网络安全学校日手抄报三年级
mysql 保存数据库
网络技术的目标分解
vba连数据库
杭州支付软件开发有什么用
网络安全与电子商务知识点
苏州德颐网络技术有限公司
网络安全的工作原则
真我x50网络技术
福州点击网络技术