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 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?