我在GridView中嵌套CheckBox,然后从数据库中绑定数据到CheckBox,数据库中的字段类型为bit,但是如果查询的数据源为空时,就会报出如下错误:
对象不能从 DBNull 转换为其他类型。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.InvalidCastException: 对象不能从 DBNull 转换为其他类型。
在绑定时有做空数据显示表头的处理的,如下:
DataSet dst = ds;
if (ds.Tables[0].Rows.Count == 0)
{
ds.Tables[0].Rows.Add(ds.Tables[0].NewRow());
GridView1.DataSource = dst;
GridView1.DataBind();
for (int i = 0; i < gv.Rows[0].Cells.Count; i++)
{
GridView1.Rows[0].Cells[i].Text = "";
}
}
else
{
GridView1.DataSource = ds;
GridView1.DataBind();
}窗体部分代码:<asp:CheckBox runat="server" AutoPostBack ="true" OnCheckedChanged ="isshow_CheckedChanged" Checked='<%# Eval("IsShow")%>'
对象不能从 DBNull 转换为其他类型。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.InvalidCastException: 对象不能从 DBNull 转换为其他类型。
在绑定时有做空数据显示表头的处理的,如下:
DataSet dst = ds;
if (ds.Tables[0].Rows.Count == 0)
{
ds.Tables[0].Rows.Add(ds.Tables[0].NewRow());
GridView1.DataSource = dst;
GridView1.DataBind();
for (int i = 0; i < gv.Rows[0].Cells.Count; i++)
{
GridView1.Rows[0].Cells[i].Text = "";
}
}
else
{
GridView1.DataSource = ds;
GridView1.DataBind();
}窗体部分代码:<asp:CheckBox runat="server" AutoPostBack ="true" OnCheckedChanged ="isshow_CheckedChanged" Checked='<%# Eval("IsShow")%>'
解决方案 »
免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货