C# debug 提示 未将对象引用设置到对象的实例。
我在赋值前给了一条输出语句看到有值了啊为啥就提示这个啊,privatevoidShowTheValue(){ChainManageDALcmdal=newChainMan...
我在赋值前给了一条输出语句 看到有值了啊 为啥就提示这个啊 , private void ShowTheValue()
{
ChainManageDAL cmdal = new ChainManageDAL();
DataTable dt = new DataTable();
DataRow dr = dt.NewRow();
dr = cmdal.GetValue(this.RowID);
Console.Write("+++++++++++++++++++++"+dr["Category"].ToString());//输出有值
txt_ShopID.Text = dr["ShopID"].ToString();//文本框赋值失败 提示未将对象引用设置到对象的实例
ChainManageDAL 这个里面我放的都是返回dataset datarow的函数直接操作数据库的
public DataRow GetValue(string RowID)
{
ds = ShowChainManage();
DataRow dr = ds.Tables[0].Rows.Find(Convert.ToInt32(RowID));
return dr;
}
是不是类之间调用有问题啊??
还是不行啊~~~~~ 展开
{
ChainManageDAL cmdal = new ChainManageDAL();
DataTable dt = new DataTable();
DataRow dr = dt.NewRow();
dr = cmdal.GetValue(this.RowID);
Console.Write("+++++++++++++++++++++"+dr["Category"].ToString());//输出有值
txt_ShopID.Text = dr["ShopID"].ToString();//文本框赋值失败 提示未将对象引用设置到对象的实例
ChainManageDAL 这个里面我放的都是返回dataset datarow的函数直接操作数据库的
public DataRow GetValue(string RowID)
{
ds = ShowChainManage();
DataRow dr = ds.Tables[0].Rows.Find(Convert.ToInt32(RowID));
return dr;
}
是不是类之间调用有问题啊??
还是不行啊~~~~~ 展开
3个回答
展开全部
1、dr["ShopID"].ToString(); 请确定ShopID与数据库中大小写一致,
2、确定dr["ShopID"] 是否有值?dr["Category"]有值不代表ShopID有值。
3、dr["ShopID"]尽量与null比较后再赋值
2、确定dr["ShopID"] 是否有值?dr["Category"]有值不代表ShopID有值。
3、dr["ShopID"]尽量与null比较后再赋值
追问
目前数据库里面是手填进去的测试数据 应该没事 我又输出了下那个ShopID 也是有值的
追答
dr["ShopID"] == null 判断一下
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的dr里面有ShopID这列吗?你输出的字段跟你赋值的字段都不是一个名字啊
更多追问追答
追问
也有啊~~ 头开始Category 这个赋值过不去 后来我就放到后了 看看行不行 结果都不行~~
追答
你可以直接输出dr["ShopID"]的内容看看输出的内容是什么
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用循环输出你获取到的dr的每一列的值,看看里面有没有“ShopID”对应的值
追问
嗯输出了~~跟数据库里面的一样啊大神~~~ 怎么办~~ 愁煞小生了~~~~~
追答
那你调试一下,到底看看哪个字段在报空,既然是这句txt_ShopID.Text = dr["ShopID"].ToString();提示空,那无非就是txt_ShopID是空或者dr["ShopID"]是空,调试看一下!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询