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

JanWarlen 2015-07-07 08:38:06
出错代码是这个。
string IOExpenditure = dGV_Record.Rows[i].Cells[0].Value.ToString();
在这代码之后我才执行插入数据,然而尽管出错,然后我停止调试,数据还是插入了。
这是什么鬼。
...全文
221 12 打赏 收藏 转发到动态 举报
AI 作业
写回复
用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{}屏蔽吧。

111,097

社区成员

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

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

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