我正在使用Oracle数据库和ASP.net MVC4创建应用程序。尽管代码中似乎没有问题,但调用SaveChanges()
方法会导致此处显示错误:
此图像显示内部异常和相关详细信息
这是我为保存更改所做的实施
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>" %>
答案 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();
}