1

レコードを更新する必要があるデータベース テーブルがあります。新しいレコードを追加するコードは正常に機能しますが、既存のレコードを更新しようとすると、すべてのフィールドがフォームの新しい情報で更新されるわけではありません。

コードは次のとおりです。

    private void updateExistingDSN()
    {
        //Update existing DSN
        try
        {
            using (PathFinderDataContext pfdcContext = new PathFinderDataContext())
            {
                DSN oldDSN = pfdcContext.DSNs.Single(dsn => dsn.DSNID == int.Parse(Request["dsn"]));

                oldDSN.Auth_AuthorizationID = int.Parse(Request["auth"]);
                oldDSN.ServiceProvided_ServiceProvidedID = int.Parse(Request["sp"]);
                oldDSN.EvidenceBPMU = short.Parse(ddlEvidenceBPMU.SelectedValue);
                oldDSN.LocationOfVisit = txtLocationOfVisit.Text;
                oldDSN.ChildrenPresent = txtNamesOfChildrenPresent.Text;
                oldDSN.ParentPresent = txtNamesOfParentsPresent.Text;
                oldDSN.OthersPresent = txtNamesOfOthersPresent.Text;
                oldDSN.DescribeGoals = txtDescribeGoals.Text;
                oldDSN.DescribeStrategy = txtDescribeStrategies.Text;
                oldDSN.DescibeParentingSkills = txtDescribeParentingSkills.Text;
                oldDSN.DescribeSafetyConcerns = txtDescribeSafetyConcerns.Text;
                oldDSN.OtherInfo = txtOtherInfo.Text;
                oldDSN.Schedule_Monday = float.Parse(txtMonday.Text);
                oldDSN.Schedule_Tuesday = float.Parse(txtTuesday.Text);
                oldDSN.Schedule_Wednesday = float.Parse(txtWednesday.Text);
                oldDSN.Schedule_Thursday = float.Parse(txtThursday.Text);
                oldDSN.Schedule_Friday = float.Parse(txtFriday.Text);
                oldDSN.Schedule_Saturday = float.Parse(txtSaturday.Text);
                oldDSN.Schedule_Sunday = float.Parse(txtSunday.Text);
                oldDSN.DateSaved = DateTime.Now;
                oldDSN.SavedBy_UserID = currentEmployee.EmployeeID;
                pfdcContext.SubmitChanges();
            }

            Response.Redirect("~/pages/updateTimesheet.aspx?action=update&ProvidedServiceId=" + int.Parse(Request["sp"]));
        }
        catch (Exception ex)
        {
            errorMessage.Text = "<b>Error updating an existing DSN record!</b><br /><br />" + ex.ToString();
            warnings.Visible = true;
        }
    }

更新される唯一のフィールドは oldDSN.DateSaved で、他のすべては同じままです。エラーや例外はスローされません。動作するように動作しますが、動作しません。また、更新する値をハードコードすると、レコードは正常に更新されます。何か案は?

4

1 に答える 1