初学者的问题,您的一句话就能帮我,而我也将散分!UPDATE PercentageSetting SET Percentage = 40,Default = 30 WHERE Item = '遵纪守法'上面是我程序运行时为了调试,我在页面上打印的。
我就不明白,生成的这条更新查询没问题丫,可为什么就报错呢???

解决方案 »

  1.   

    完整的信息是这样的:
    “/IAS2”应用程序中的服务器错误。
    --------------------------------------------------------------------------------操作必须使用一个可更新的查询。 
    说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.Data.OleDb.OleDbException: 操作必须使用一个可更新的查询。源错误: 
    行 175: hhd = sql;
    行 176: OleDbCommand cmd = new OleDbCommand(sql,DataParent.connAssessment);
    行 177: cmd.ExecuteNonQuery();
    行 178: temp = true;
    行 179: }
     源文件: c:\inetpub\wwwroot\ias2\data\assessment.cs    行: 177 堆栈跟踪: 
    [OleDbException (0x80004005): 操作必须使用一个可更新的查询。]
       System.Data.OleDb.OleDbCommand.ExecuteCommandTextErrorHandling(Int32 hr)
       System.Data.OleDb.OleDbCommand.ExecuteCommandTextForSingleResult(tagDBPARAMS dbParams, Object& executeResult)
       System.Data.OleDb.OleDbCommand.ExecuteCommandText(Object& executeResult)
       System.Data.OleDb.OleDbCommand.ExecuteCommand(CommandBehavior behavior, Object& executeResult)
       System.Data.OleDb.OleDbCommand.ExecuteReaderInternal(CommandBehavior behavior, String method)
       System.Data.OleDb.OleDbCommand.ExecuteNonQuery()
       IAS2.Data.Assessment.UpdateSetting(Object[,] setting) in c:\inetpub\wwwroot\ias2\data\assessment.cs:177
       IAS2.PerfDataOperation.btnOK_Click(Object sender, EventArgs e) in c:\inetpub\wwwroot\ias2\perfdataoperation.aspx.cs:186
       System.Web.UI.WebControls.LinkButton.OnClick(EventArgs e)
       System.Web.UI.WebControls.LinkButton.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument)
       System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument)
       System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData)
       System.Web.UI.Page.ProcessRequestMain() 
    --------------------------------------------------------------------------------
    版本信息: Microsoft .NET Framework 版本:1.1.4322.573; ASP.NET 版本:1.1.4322.573
      

  2.   

    我现在怀疑是连接的问题。
    可能是我写得太简单了。
    private static string provider2 = @"Data Source=C:\Inetpub\wwwroot\IAS2\Data\Assessment.mdb;Provider=Microsoft.Jet.OLEDB.4.0";
      

  3.   

    可能Assessment.mdb是只读的,或者Aspnet用户没有对Assessment.mdb的写权限,请在该文件上右击,在“属性”-》“安全”选项卡内给予相应的权限。
      

  4.   

    原因:
    有几个主要的错误原因:
    这个错误发生在当你的程序试图执行更新数据库或其它类似操作时。这是因为
    ADO由于以下的几个原因而不能够写数据库造成的。
    1。最普遍的原因是匿名用户帐号(IUSR_MACHINE)对该数据库文件没有写权限。 
    要解决这个问题,在管理器中调整数据库文件的属性,让匿名用户有正确的权限。
    当使用ACCESS数据库时,不仅要给文件写的权限,还要给该目录写 的权限,因为
    Jet需要在该目录建立一个.ldb文件。
    2。第二个原因是数据库没有使用正确的模式打开。应该使用下面的方法打开。
    SQL = "UPDATE Products Set UnitPrice = 2;"
    Set Conn = Server.CreateObject("ADODB.Connection")
    Conn.Mode = 3 '3 = adModeReadWrite
    Conn.Open "myDSN"
    Conn.Execute(SQL)
    Conn.Close
    注意默认的Mode是设置0(adModeUnknown),它是允许更新的。
    3。还有可能是在ODBC管理器中将该DSN的只读选项选中。
    4。你是在同时更新两个表中的字段,也会出现这个错误信息,解决办法是分开来更新
    这两个表中各自字段。
    5。当你使用了一个从低版本中(如ACCESS2.0,ACCESS7.0)载入到高版本(ACCESS 2000)
    中的查询时,在执行这个查询是会出现该错误。