“SaveChanges()”方法出错

时间:2014-12-16 09:47:25

标签: c# asp.net-mvc asp.net-mvc-4

我正在使用Oracle数据库和ASP.net MVC4创建应用程序。尽管代码中似乎没有问题,但调用SaveChanges()方法会导致此处显示错误:

enter image description here

此图像显示内部异常和相关详细信息

enter image description here

这是我为保存更改所做的实施

if (ModelState.IsValid)
{
    ModelState.Clear();

    using (SSP_Entities database = new SSP_Entities())
    {
          database.REQUEST_TAB.Add(c_modal.Request_tab);
          database.SaveChanges();
          caseID = c_modal.Request_tab.CASE_ID;
          return RedirectToAction("NewEnv", cpe);
     }
  }

我在视图中使用以下代码

    <%:Html.HiddenFor(model => model.request_tab.ROWVERSION, new { @Value="date"}) %>
    <%:Html.HiddenFor(model => model.request_tab.CASE_ID, new { @Value=100}) %>
    <%:Html.HiddenFor(model => model.request_tab.REQUEST_BY, new { @Value="PUSNLK"}) %>
    <%:Html.HiddenFor(model => model.request_tab.REQUEST_ID, new { @Value=334}) %>
    <%:Html.HiddenFor(model => model.request_tab.REQUEST_TYPE, new { @Value="CPE"}) %>
    <%:Html.HiddenFor(model => model.request_tab.STATE, new { @Value="POSTED"}) %>
    <%:Html.HiddenFor(model => model.request_tab.COMMENTS, new { @Value="CPE Order"}) %>

这是我正在使用的模型

namespace CPEASPX.Models
{
    using System;
    using System.Collections.Generic;

    public partial class REQUEST_TAB
    {
        public decimal REQUEST_ID { get; set; }
        public string REQUEST_BY { get; set; }
        public decimal CASE_ID { get; set; }
        public string STATE { get; set; }
        public string REQUEST_TYPE { get; set; }
        public string ROWVERSION { get; set; }
        public string COMMENTS { get; set; }
    }
}

我尝试了其他地方展示的一些解决方案。首先,我通过添加

更改了<appSettings>文件中的web.config
<add key="aspnet:MaxHttpCollectionKeys" value="5000" />
<add key="aspnet:MaxJsonDeserializerMembers" value="5000" />
<add key="aspnet:MaxHttpCollectionKeys" value="10000" />

线条。但问题还在继续。我找不到客户端和服务器数据类型之间的任何不匹配。

请帮我解决问题。

这里我将两个模型传递给一个视图。我为此创建了以下组合模型(c_model是此类的对象)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace CPEASPX.Models
{
    public class CombineModal
    {
        public REQUEST_TAB request_tab = new REQUEST_TAB();

        public REQUEST_TAB Request_tab
        {
        get { return request_tab; }
        set { request_tab = value; }
        }


        public CPE cpe = new CPE();

        public CPE Cpe
        {
            get { return cpe; }
            set { cpe = value; }
        }
    }
}

这里它说我将CPE模型传递给它但我只传递了包含CPE模态和Request_tab模式的组合模型。

这是我在视图中用来继承模态类

的代码
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<CPEASPX.Models.CombineModal>" %>

1 个答案:

答案 0 :(得分:1)

我认为你需要分配每个属性而不是添加整个类。

using (SSP_Entities database = new SSP_Entities())
{
    var requestTab = new RequestTab
    {
        REQUEST_ID = c_modal.Request_tab.REQUEST_ID,
        REQUEST_BY = c_modal.Request_tab.REQUEST_BY,
        CASE_ID = c_modal.Request_tab.CASE_ID,
        STATE = c_modal.Request_tab.STATE,
        REQUEST_TYPE = c_modal.Request_tab.REQUEST_TYPE,
        ROWVERSION = c_modal.Request_tab.ROWVERSION,
        COMMENTS = c_modal.Request_tab.COMMENTS
    };

    database.REQUEST_TAB.Add(requestTab);
    database.SaveChanges();
}