一个关于asp.net中textbox控件的onchanged控件事情来实现数据库在textbox失去焦点的时候,更新数据库..
本人利用的是access数据库和gridview控件,想实现当gridview中第五列的textbox的值发生变化是,利用textbox的onchanged的事情当tex...
本人利用的是access数据库和gridview控件,想实现当gridview中第五列的textbox的值发生变化是,利用textbox的onchanged的事情当textbox失去焦点的时候,更新数据库..
cs代码如下: protected void TextBox2_TextChanged(object sender, GridViewRowEventArgs e)
{
TextBox tb = (TextBox)GridView1.FindControl("TextBox2");//这里找控件的写法是错了吗?调试的时候为空值,请纠正...!!!
string conn = Server.MapPath("~/shuju/dxgs.mdb");
OleDbConnection sqlconn = new OleDbConnection("PROVIDER=Microsoft.Jet.OLEDB.4.0; DATA source=" + conn);
sqlconn.Open();
string strupadt = "";
strupadt = "update ch_wp set ch_px=@px ";
OleDbCommand cmd = new OleDbCommand(strupadt, sqlconn);
cmd.Parameters.Add("@ch_px", OleDbType.Integer);
cmd.Parameters["@ch_px"].Value = tb.Text.ToString();
cmd.ExecuteNonQuery();
sqlconn.Close();
} 展开
cs代码如下: protected void TextBox2_TextChanged(object sender, GridViewRowEventArgs e)
{
TextBox tb = (TextBox)GridView1.FindControl("TextBox2");//这里找控件的写法是错了吗?调试的时候为空值,请纠正...!!!
string conn = Server.MapPath("~/shuju/dxgs.mdb");
OleDbConnection sqlconn = new OleDbConnection("PROVIDER=Microsoft.Jet.OLEDB.4.0; DATA source=" + conn);
sqlconn.Open();
string strupadt = "";
strupadt = "update ch_wp set ch_px=@px ";
OleDbCommand cmd = new OleDbCommand(strupadt, sqlconn);
cmd.Parameters.Add("@ch_px", OleDbType.Integer);
cmd.Parameters["@ch_px"].Value = tb.Text.ToString();
cmd.ExecuteNonQuery();
sqlconn.Close();
} 展开
4个回答
展开全部
请注意你的page_load事件中是否有gridview初始化的代码,一定要加上if(!page.isPostback)判断,不然你触发TextBox2_TextChanged事件时先执行了page_load中初始化GRIDVIEW的数据,那么取到的textbox2就是原来数据库中的数据
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
是的 你在Gridview里面查找控件 要指定行 来查找, 你在这里不需要这样查找,因为这是在Textbx的change事件里面,直接 TextBox tb=send as TextBox;就可以了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
应该是这样的吧,在后面加TextBox2的Text属性
TextBox tb =( (TextBox)GridView1.FindControl("TextBox2").Text);
TextBox tb =( (TextBox)GridView1.FindControl("TextBox2").Text);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询