Nealson&wch 2022-01-12 09:00 采纳率: 100%
浏览 33
已结题

c#读取txt到Access并进行操作,数据量大的时候必须打开数据库,否则会报错,搞不清了?

txt数据已经读入表1中,在利用表1数据统计最大最小值并记录到表2中时,如果数据量较大,则必须打开数据库,否则会报DBNULL的错误 :对象不能从 DBNull 转换为其他类型

OleDbDataAdapter readHDM = new OleDbDataAdapter("select * from HDM", oledb);
        DataSet dmdatas = new DataSet();
        readHDM.Fill(dmdatas, "HDM");
        OleDbDataAdapter adapterdmh = new OleDbDataAdapter("SELECT * from HDM where 断面号<>''", oledb);
        DataSet dmid = new DataSet();
        adapterdmh.Fill(dmid, "HDM");

        DataRow r = dmid.Tables[0].NewRow();
        r["ID"] = dmdatas.Tables[0].Rows.Count + 1;
        r["断面号"] = "结束";
        dmid.Tables[0].Rows.Add(r);
        int rows = dmid.Tables[0].Rows.Count;//统计断面个数
        this.dataGridView2.DataSource=dmid.Tables[0];

        for (int i = 0; i < rows - 1; i++)
        {
            ArrayList LC = new ArrayList();//里程
            ArrayList GC = new ArrayList();//高程
           
            int starti = (int)dmid.Tables[0].Rows[i][0] - 1;
            int endi = (int)dmid.Tables[0].Rows[i + 1][0] - 1;
            for (int k = starti + 1; k < endi; k++)//遍历每个断面
            {
                double LCdata = Convert.ToDouble(dmdatas.Tables[0].Rows[k][2]);
                double GCdata = Convert.ToDouble(dmdatas.Tables[0].Rows[k][3]);
                LC.Add(LCdata);
                GC.Add(GCdata);
            }
            double LClength = LC.Count;
            double GClength = GC.Count; 

![img](

######https://img-mid.csdnimg.cn/release/static/image/mid/ask/003771949146174.png "#left")

  • 写回答

2条回答 默认 最新

  • CSDN专家-showbo 2022-01-12 09:03
    关注

    dmdatas.Tables[0].Rows[k][2]);这行数据的第三列数据为null,无法转换,应该判断是否有值在转换,否则默认一个值,如0

    double LCdata =0;
    if(dmdatas.Tables[0].Rows[k][2].ToString()!="") LCdata = Convert.ToDouble(dmdatas.Tables[0].Rows[k][2]);
    double GCdata =0;
    if(dmdatas.Tables[0].Rows[k][3].ToString()!="") GCdata = Convert.ToDouble(dmdatas.Tables[0].Rows[k][3]);
    
    

    img


    有其他问题可以继续交流~

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月20日
  • 已采纳回答 1月12日
  • 创建了问题 1月12日

悬赏问题

  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上