菜鸟问题~谢谢大家

jerrykan 2004-10-27 11:04:16
不知道为什么不能更新数据

<% @ Page Language="C#" Debug="true" %>
<% @ Import Namespace="System.Data" %>
<% @ Import Namespace="System.Data.OleDb" %>
<Script Language="C#" Runat="Server">
OleDbConnection MyConn;
public void Page_Load(Object src,EventArgs e)
{
//连接语句
string MyConnString = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="+Server.MapPath(".")+"/db1.mdb;";
MyConn = new OleDbConnection(MyConnString);
MyConn.Open();

if(!Page.IsPostBack)
{
ListBind();
}
}

ICollection CreateSource()
{
string strSel = "select * from Score";
DataSet ds = new DataSet();

OleDbDataAdapter MyAdapter = new OleDbDataAdapter(strSel,MyConn);
MyAdapter.Fill(ds,"Score");

return ds.Tables["Score"].DefaultView;
}
public void ListBind()
{
score.DataSource = CreateSource();
score.DataBind();
}
public void DataList_EditCommand(Object sender,DataListCommandEventArgs e)
{
score.EditItemIndex = (int)e.Item.ItemIndex;
ListBind();
}
public void DataList_CancelCommand(Object sender,DataListCommandEventArgs e)
{
score.EditItemIndex = -1;
ListBind();
}
public void DataList_UpdateCommand(Object sender,DataListCommandEventArgs e)
{
string strItemmc = ((Label)e.Item.FindControl("lblItemmc")).Text;
string strItemfzr = ((TextBox)e.Item.FindControl("tdItemfzr")).Text;
string strItemlcfs = ((TextBox)e.Item.FindControl("tdItemlcfs")).Text;
string strItemsj = ((TextBox)e.Item.FindControl("tdItemsj")).Text;
string strItemjssj = ((TextBox)e.Item.FindControl("tdtbItemjssj")).Text;
string strItembak = ((TextBox)e.Item.FindControl("tdItembak")).Text;
//更新数据库中的数据
string strUpdate = "Update Score Set Itemfzr='"+strItemfzr+"',Itemlcfs='"+strItemlcfs+"',Itemsj='"+strItemsj+"',Itemjssj='"+strItemjssj+"',Itembak='"+strItembak+"' Where Itemmc='"+strItemmc+"'";
OleDbCommand MyComm = new OleDbCommand(strUpdate,MyConn);
MyComm.ExecuteNonQuery();

score.EditItemIndex = -1;
ListBind();
}
</script>
<html>
<head>
<title></title>
</head>
<body>
<form runat="server">
<asp:DataList id="score" runat="server"
HeaderStyle-BackColor="#aaaadd"
AlternatingItemStyle-BackColor="Gainsboro"
EditItemStyle-BackColor="yellow"
RepeatLayout="Table"
OnEditCommand="DataList_EditCommand"
OnUpdateCommand="DataList_UpdateCommand"
OnCancelCommand="DataList_CancelCommand"
>
<HeaderTemplate>
项目列表
</HeaderTemplate>
<ItemTemplate>
项目名称:<%# DataBinder.Eval(Container.DataItem,"Itemmc") %>
<asp:LinkButton id="btnSelect" Text="编辑" CommandName="edit" runat="server" />
</ItemTemplate>
<EditItemTemplate>
项目名称:<asp:Label id="lblItemmc" Text='<%# DataBinder.Eval(Container.DataItem,"Itemmc") %>' runat="server" /><br>
项目负责人:<asp:TextBox id="tbItemfzr" Text='<%# DataBinder.Eval(Container.DataItem,"Itemfzr") %>' runat="server" /><br>
项目委托方联系方式:<asp:TextBox id="tbItemlcfs" Text='<%# DataBinder.Eval(Container.DataItem,"Itemlcfs") %>' runat="server" /><br>
项目时间:<asp:TextBox id="tbItemsj" Text='<%# DataBinder.Eval(Container.DataItem,"Itemsj") %>' runat="server" /><br>
项目时间:<asp:TextBox id="tbItemjssj" Text='<%# DataBinder.Eval(Container.DataItem,"Itemjssj") %>' runat="server" /><br>
项目备注: <asp:TextBox id="tbItembak" Text='<%# DataBinder.Eval(Container.DataItem,"Itembak") %>' runat="server" /><br>
<asp:LinkButton id="lbnUpdate" Text="更新" CommandName="update" runat="server" />
<asp:LinkButton id="lbnCancel" Text="取消" CommandName="cancel" runat="server" />
</EditItemTemplate>
</asp:DataList>

</form>
</body>
</html>

显示这一句有错误
...全文
194 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
penning 2004-10-27
  • 打赏
  • 举报
回复
string strItemfzr = ((TextBox)e.Item.FindControl("tdItemfzr")).Text;
--》
string strItemfzr = ((TextBox)e.Item.FindControl("tbItemfzr")).Text;
xiaohutushen 2004-10-27
  • 打赏
  • 举报
回复
up
cuike519 2004-10-27
  • 打赏
  • 举报
回复
string strItemfzr = ((TextBox)e.Item.FindControl("tdItemfzr")).Text;
这一句本身就有问题,如果程序按照你预计的执行那么没有问题,但是通常不是这样的。
你没有判断tdItemfzr这个控件是否存在,就直接转换后.Text。这样是不对的,以下的做法比较安全:
Control ctl = e.Item.FindControl("tdItemfzr");
if(ctl!=null && ctl is TextBox){
strItemfzr = ((TextBox)e.Item.FindControl("tdItemfzr")).Text;
}
else{
strItemfzr = "";
luaiping 2004-10-27
  • 打赏
  • 举报
回复
tbItemfzr?tdItemfzr?
写错了吧
nmlvjun 2004-10-27
  • 打赏
  • 举报
回复
可能没找到控件,tdItemfzr是控件名吗?
jerrykan 2004-10-27
  • 打赏
  • 举报
回复
显示这一句有错误
string strItemfzr = ((TextBox)e.Item.FindControl("tdItemfzr")).Text;
表里全部是文本类型字段.
jerrykan 2004-10-27
  • 打赏
  • 举报
回复
问题找到了 penning(飞鱼)大哥正解~

62,266

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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