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 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵