2013-02-10 86 views
1

我想更新我的访问数据库中的值,但它在某些情况下不起作用。asp.net访问数据库没有更新

代码:

<form id="form1" runat="server"> 
<asp:AccessDataSource ID="AccessDataSource1" runat="server" 
     DataFile="~/App_Data/Database1.mdb" 
     DeleteCommand="UPDATE DT_Person SET Deleted = NOW() WHERE (Person_Ref = ?)" 
     InsertCommand="INSERT INTO [DT_Person] ([Person_Ref], [Created], [Updated], [Deleted],  [Person_Name], [Person_No]) VALUES (?, ?, ?, ?, ?, ?)" 
     OldValuesParameterFormatString="original_{0}" 
     SelectCommand="SELECT * FROM [DT_Person]" 
     UpdateCommand="UPDATE DT_Person SET Updated = NOW(), Person_Name = ?, Person_No = ? WHERE (Person_Ref = ?)"> 
     <DeleteParameters> 
      <asp:Parameter Name="original_Person_Ref" Type="Int32" /> 
     </DeleteParameters> 
     <UpdateParameters> 
      <asp:Parameter Name="Created" Type="DateTime" /> 
      <asp:Parameter Name="Updated" Type="DateTime" /> 
      <asp:Parameter Name="Deleted" Type="DateTime" /> 
      <asp:Parameter Name="Person_Name" Type="String" /> 
      <asp:Parameter Name="Person_No" Type="String" /> 
      <asp:Parameter Name="original_Person_Ref" Type="Int32" /> 
     </UpdateParameters> 
     <InsertParameters> 
      <asp:Parameter Name="Person_Ref" Type="Int32" /> 
      <asp:Parameter Name="Created" Type="DateTime" /> 
      <asp:Parameter Name="Updated" Type="DateTime" /> 
      <asp:Parameter Name="Deleted" Type="DateTime" /> 
      <asp:Parameter Name="Person_Name" Type="String" /> 
      <asp:Parameter Name="Person_No" Type="String" /> 
     </InsertParameters> 
    </asp:AccessDataSource> 
    <asp:GridView ID="GridView1" runat="server" AllowPaging="True" 
     AllowSorting="True" AutoGenerateColumns="False" BackColor="White" 
     BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" CellPadding="3" 
     DataKeyNames="Person_Ref" DataSourceID="AccessDataSource1"> 
     <RowStyle ForeColor="#000066" /> 
     <Columns> 
      <asp:CommandField ShowDeleteButton="True" ShowEditButton="True" 
       ShowSelectButton="True" /> 
      <asp:BoundField DataField="Person_Ref" HeaderText="Person_Ref" 
       InsertVisible="False" ReadOnly="True" SortExpression="Person_Ref" /> 
      <asp:BoundField DataField="Created" HeaderText="Created" 
       SortExpression="Created" /> 
      <asp:BoundField DataField="Updated" HeaderText="Updated" 
       SortExpression="Updated" /> 
      <asp:BoundField DataField="Deleted" HeaderText="Deleted" 
       SortExpression="Deleted" /> 
      <asp:BoundField DataField="Person_Name" HeaderText="Person_Name" 
       SortExpression="Person_Name" /> 
      <asp:BoundField DataField="Person_No" HeaderText="Person_No" 
       SortExpression="Person_No" /> 
     </Columns> 

正如你所看到的,delete命令

(DeleteCommand="UPDATE DT_Person SET Deleted = NOW() WHERE (Person_Ref = ?)") 

是一个真正的更新语句,并能正常工作。但是,实际的更新声明不适用于网页。奇怪的是,如果你在'查询生成器'中测试查询,它工作正常。

真的需要一些帮助。

TIA

P.S.我使用Visual Studio 2008和每次使用数据源构建器

+0

我刚刚测试过,它适用于我。你收到什么错误信息?你有没有在Access文件和文件夹上的权限? – Fionnuala 2013-02-10 14:49:30

回答

0

Windows 7(如果这就是您使用的)已知在调试文件中将Access数据库的副本向下并对所有数据使用副本变化。您可能想要检查您实际访问的数据库是否是您认为的副本。

在整个开发机器上搜索具有相同名称的文件。你可能会惊讶什么出现。