我有一个显示数据库数据的gridview。数据库将图像文件名(字符串)存储在一个项目中。通过gridview上传图片的问题
我有文件上载控件显示在编辑视图,并上传文件就好了。
问题是,我想更新数据库中的图像文件名,我不知道如何获取数据到gridview控件的gridview用来更新数据库。我已将文字框控件设置为隐藏。这里是ASPX代码:
<asp:TemplateField HeaderText="Image" SortExpression="Image">
<EditItemTemplate>
<asp:TextBox ID="txtImage" runat="server" Text='<%# Bind("Image") %>' Visible="False" OnTextChanged="txtImage_TextChanged"></asp:TextBox>
<asp:FileUpload ID="FileUpload1" runat="server" />
</EditItemTemplate>
<ItemTemplate>
<asp:Image ID="Image1" runat="server" Width="50px" AlternateText='<%# Eval("Image") %>' ImageUrl='<%# "images/hardware/" + Eval("Image") %>' />
</ItemTemplate>
</asp:TemplateField>
这里是存储文件到服务器的功能,以及文件名放到一个变量:
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
GridViewRow row = GridView1.Rows[e.RowIndex];
FileUpload fileUpload = row.Cells[0].FindControl("FileUpload1") as FileUpload;
if (fileUpload != null && fileUpload.HasFile)
{
strFileName = fileUpload.FileName;
fileUpload.SaveAs(Server.MapPath("images/hardware/" + strFileName));
TextBox txtImage = row.Cells[0].FindControl("txtImage") as TextBox;
txtImage.Text = strFileName;
}
}
那么,我该何去何从?我认为这个更新已经发生了或者什么?因为“txtImage.Text”不更新数据库...我在这里或什么地方出了问题?在将它保存到数据库之前,我可以在此函数的文本框中操纵值?感谢您的帮助。
没有真正更新后面的代码我不认为......我正在使用数据集的“UpdateQuery”属性来处理更新。 – Kolten 2009-04-27 22:21:32