C# 插入mdb数据库,错误报“未将对象引用设置到对象的实例”。

JanWarlen 2015-07-07 08:38:06
出错代码是这个。
string IOExpenditure = dGV_Record.Rows[i].Cells[0].Value.ToString();
在这代码之后我才执行插入数据,然而尽管出错,然后我停止调试,数据还是插入了。
这是什么鬼。
...全文
200 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
引用 10 楼 Z65443344 的回复:
此外,如果你从后台的数据源DataTable取值,而不是直接从表格里取值,那么就不存在最后一行是空值的情况 至于什么插入数据库成功 你没用事务,而是循环插入,那么当然前面的行没有问题就插入成功了,后面有的行有问题就插入不成功了 而不是要么都插入成功,要么都不插入 还有你那3个if嵌套,如果是前面没有问题的行,当然3层都能走进去 你应该调试的是后面出错的行 不出错的行调试它干啥
一直是在野生的情况,我现在再看黑马程序员的视频,请问自学C#有什么大致的阶段和方向么。
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
引用 10 楼 Z65443344 的回复:
此外,如果你从后台的数据源DataTable取值,而不是直接从表格里取值,那么就不存在最后一行是空值的情况 至于什么插入数据库成功 你没用事务,而是循环插入,那么当然前面的行没有问题就插入成功了,后面有的行有问题就插入不成功了 而不是要么都插入成功,要么都不插入 还有你那3个if嵌套,如果是前面没有问题的行,当然3层都能走进去 你应该调试的是后面出错的行 不出错的行调试它干啥
当时知道要把最后一行跳过,然而给忘了,因此处于认为跳过空白行的情况。
於黾 2015-07-07
  • 打赏
  • 举报
回复
此外,如果你从后台的数据源DataTable取值,而不是直接从表格里取值,那么就不存在最后一行是空值的情况 至于什么插入数据库成功 你没用事务,而是循环插入,那么当然前面的行没有问题就插入成功了,后面有的行有问题就插入不成功了 而不是要么都插入成功,要么都不插入 还有你那3个if嵌套,如果是前面没有问题的行,当然3层都能走进去 你应该调试的是后面出错的行 不出错的行调试它干啥
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
引用 7 楼 Z65443344 的回复:
还有,最大的可能性是因为你的DGV设置了允许用户增加行 这样最后一行就是个新增行,里面的值就都是空值 要么去掉允许用户新增行的选项 要么代码判断一下如果是最后一行就不要插入数据库
是这个问题。。。多谢。忘了给
int num = dGV_Record.Rows.GetRowCount(DataGridViewElementStates.Visible);
                for (int i = 0; i < num; i++)
num-1了。
於黾 2015-07-07
  • 打赏
  • 举报
回复
还有,最大的可能性是因为你的DGV设置了允许用户增加行 这样最后一行就是个新增行,里面的值就都是空值 要么去掉允许用户新增行的选项 要么代码判断一下如果是最后一行就不要插入数据库
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
引用 5 楼 Z65443344 的回复:
你的i是个变量,是行号 所以可能前10行都没有错误,第11行就出错 你应该判断如果有为空的数据,才弹出窗口显示,而不是无脑弹窗 目测应该是dGV_Record.Rows[i].Cells[0].Value的值是空 空值不能转字符串
string IOExpenditure = dGV_Record.Rows[i].Cells[0].Value.ToString();
如果为空倒是简单了,现在是赋值成功并且插入数据库了。 麻烦请仔细看看,谢谢。 至于那个不为空弹窗,那三层下来都不为空,才会弹窗,if是嵌套的。
於黾 2015-07-07
  • 打赏
  • 举报
回复
此外,最简单的调试方式 就是不要胡乱加什么弹窗 用原来的代码直接运行 然后它会报错,代码自动停在出错的代码行 这时候你在调试器里依次看i是多少,每个值都是多少
於黾 2015-07-07
  • 打赏
  • 举报
回复
你的i是个变量,是行号 所以可能前10行都没有错误,第11行就出错 你应该判断如果有为空的数据,才弹出窗口显示,而不是无脑弹窗 目测应该是dGV_Record.Rows[i].Cells[0].Value的值是空 空值不能转字符串
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
引用 1 楼 bdmh 的回复:
自己一次检查 dGV_Record.Rows[i] dGV_Record.Rows[i].Cells[0] dGV_Record.Rows[i].Cells[0].Value 是不是空值
if (dGV_Record.Rows[i] != null)
                {
                    if (dGV_Record.Rows[i].Cells[0] != null)
                    {
                        if (dGV_Record.Rows[i].Cells[0].Value != null)
                        {
                            MessageBox.Show(dGV_Record.Rows[i].Cells[0].Value.ToString());
                        }
messagebox消息有提示,提示了内容。
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
引用 1 楼 bdmh 的回复:
自己一次检查 dGV_Record.Rows[i] dGV_Record.Rows[i].Cells[0] dGV_Record.Rows[i].Cells[0].Value 是不是空值
数据插入到数据库中了。这才是头疼的地方。现在报错是,它报错,然而顺道把数据插入数据库了。 不是空值,我做了空值判断后,就提示我使用为赋值的局部变量。。。
bdmh 2015-07-07
  • 打赏
  • 举报
回复
自己一次检查 dGV_Record.Rows[i] dGV_Record.Rows[i].Cells[0] dGV_Record.Rows[i].Cells[0].Value 是不是空值
JanWarlen 2015-07-07
  • 打赏
  • 举报
回复
int num = dGV_Record.Rows.GetRowCount(DataGridViewElementStates.Visible);
            for (int i = 0; i < num; i++) 
这段代码是出错语句之前的代码,如果dGV_Record为null,那就不会进入循环内部了啊。这出错是什么机制? 总不能用try{}catch{}屏蔽吧。
本文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。 1.通过ADO.NET的OleDb相关类来操作Access 主要知识点如下: using System.Data.OleDb; using System.Data; 连接字符串:String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb"; 建立连接:OleDbConnection connection = new OleDbConnection(connectionString); 使用OleDbCommand类来执行Sql语句: OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery(); 2.取得Access自增标识字段在插入数据后的id值 cmd.CommandText = @"select @@identity"; int value = Int32.Parse(cmd.ExecuteScalar().ToString()); return value; 3.执行事务 需要用到OleDbTransaction,关键语句如下: OleDbConnection connection = new OleDbConnection(connectionString); OleDbCommand cmd = new OleDbCommand(); OleDbTransaction transaction = null; cmd.Connection = connection; connection.Open(); transaction = connection.BeginTransaction(); cmd.Transaction = transaction; cmd.CommandText=sql1; cmd.ExecuteNonQuery(); cmd.CommandText=sql2; cmd.ExecuteNonQuery(); transaction.Commit(); 4.执行查询,返回DataSet OleDbConnection connection = new OleDbConnection(connectionString); DataSet ds = new DataSet(); connection.Open(); OleDbDataAdapter da = new OleDbDataAdapter(sql, connection); da.Fill(ds,"ds"); 5.分页查询 分页查询使用OleDbDataReader来读取数据,并将结果写到一个DataSet中返回。 以上内容封装为三个可重用的类:AccessDBUtil,AccessPageUtil,Page 代码这里下载AccessDBUtilDemo.rar (191.37 KB , 下载:999次) 本例程是一个c#的winform程序,但是数据访问类可以在Web环境下使用。 本例程演示了: 1.Access数据库插入,更新,修改,查询; 2.带参数的sql语句的使用,而不是拼SQL; 3.使用DataReader的分页查询,而不是用嵌套的SQL语句来分页; 4.用事务同时执行多个SQL语句; 5.在插入数据的同时返回最新的ID值; 6.整型,实型,字符串,日期型,布尔型五种数据类型的操作; 7.使用正则表达式来验证整数和实数; 8.listview用来显示数据的一些基本用法。 本示例不包括: 1.高效的分页查询,仅仅是提供了一种分页的方法,但我认为DataReader应该比嵌套的SQL语句快(测试)。 2.完善的分页封装,只提供了分页的简单包装。 3.嵌套的事务处理,提供了同时执行多个sql语句的事务处理,但不支持嵌套事务。 4.listview的使用,只是利用winform控件来演示数据访问,因此不能作为winform编程的良好示例,例如添加数据时界面并没有很好地更新。

110,538

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧