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日

悬赏问题

  • ¥115 用Java解决探地雷达dzt文件的解析过程
  • ¥20 有关神经网络这道(b)determine the parameters of neural network
  • ¥25 annaconda jvpyter
  • ¥20 来一个会抓包app支付接口的
  • ¥30 vivado2017.4的sdk打不开
  • ¥50 matlab,文献复现
  • ¥20 寻找Flink CDC指导,有偿咨询
  • ¥15 cruise如何仿真不同温度下车辆的经济性?
  • ¥20 扑克牌游戏的完整代码
  • ¥88 求帮安装Python架构的vnpy