EntityCommandExecutionException не было обработано
Я пишу приложение, используя EF 4.1 MVC3. Я пытаюсь реализовать CRUD на нем. Проблема в том, что когда я пытаюсь реализовать только первую индексную страницу, это дает мне ошибку. Я использую внешнюю базу данных с центрального сервера. Я просто пробую простую регистрационную форму. У меня есть первая модель класса RegModel.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace Registration.Models
{
public class Register
{
public int Id { get; set; }
public string UserName { get; set; }
public string Password { get; set; }
public string Email { get; set; }
public string Address { get; set; }
}
}
Затем RegModelContext.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace Registration.Models
{
public class Register
{
public int Id { get; set; }
public string UserName { get; set; }
public string Password { get; set; }
public string Email { get; set; }
public string Address { get; set; }
}
}
Мое имя контроллера RegController.cs (я просто пытаюсь сначала реализовать Index.) В контроллере. Когда я выполняю свое заявление, это дало мне ошибку на return View(db.Registrant.ToString());
что "entitycommandexecutionexception был необработан"
"Произошла ошибка при выполнении определения команды. Подробности смотрите во внутреннем исключении".
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using Registration.Models;
using System.Configuration;
namespace Registration.Controllers
{
public class RegController : Controller
{
//
// GET: /Reg/
private string CmdStr = ConfigurationManager.ConnectionStrings["MyConn"].ConnectionString;
public ActionResult Index()
{
using (var db = new RegModelContext(CmdStr))
{
return View(db.Registrant.ToString());
}
}
}
}
Затем с помощью индекса я создаю представление для индекса (Index.cshtml):
@model IEnumerable<Registration.Models.Register>
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<title>Index</title>
</head>
<body>
<p>
@Html.ActionLink("Create New", "Create")
</p>
<table>
<tr>
<th></th>
<th>
UserName
</th>
<th>
Password
</th>
<th>
Email
</th>
<th>
Address
</th>
</tr>
@foreach (var item in Model) {
<tr>
<td>
@Html.ActionLink("Edit", "Edit", new { id=item.Id }) |
@Html.ActionLink("Details", "Details", new { id=item.Id }) |
@Html.ActionLink("Delete", "Delete", new { id=item.Id })
</td>
<td>
@item.UserName
</td>
<td>
@item.Password
</td>
<td>
@item.Email
</td>
<td>
@item.Address
</td>
</tr>
}
</table>
</body>
</html>
Я использую этот файл web.config
<?xml version="1.0" encoding="utf-8"?>
<!--
For more information on how to configure your ASP.NET application, please visit
http://go.microsoft.com/fwlink/?LinkId=152368
-->
<configuration>
<configSections>
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=4.3.1.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
</configSections>
<appSettings>
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
</appSettings>
<system.web>
<compilation debug="true" targetFramework="4.0">
<assemblies>
<add assembly="System.Web.Abstractions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Helpers, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Routing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.WebPages, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
</assemblies>
</compilation>
<authentication mode="Forms">
<forms loginUrl="~/Account/LogOn" timeout="2880" />
</authentication>
<pages>
<namespaces>
<add namespace="System.Web.Helpers" />
<add namespace="System.Web.Mvc" />
<add namespace="System.Web.Mvc.Ajax" />
<add namespace="System.Web.Mvc.Html" />
<add namespace="System.Web.Routing" />
<add namespace="System.Web.WebPages" />
</namespaces>
</pages>
</system.web>
<system.webServer>
<validation validateIntegratedModeConfiguration="false" />
<modules runAllManagedModulesForAllRequests="true" />
</system.webServer>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-2.0.0.0" newVersion="3.0.0.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
<connectionStrings>
<add name="MyConn" connectionString="Data Source=WIN-A32JMN2HC3A\SAIGMAMSSQL;Initial Catalog=Registration;User Id=SAIGMA110;Password=12345;"/>
</connectionStrings>
</configuration>
1 ответ
Проблема с этим кодом:
string CmdStr = ConfigurationManager.ConnectionStrings["MyConn"].ConnectionString;
using (var db = new RegModelContext(CmdStr))
{
return View(db.Registrant.ToString());
}
Во-первых, вам не нужно явно указывать строку подключения. По соглашению Entity Framework будет искать подходящую строку подключения в вашем файле web.config. Просто убедитесь, что имя строки подключения совпадает с именем вашего DbContext.
Во-вторых, вы получаете доступ к коллекции Register
объекты в вашей базе данных корыто db.Registrant
, призвание ToString()
на это не имеет никакого смысла.
Ваше мнение ожидает список Registration.Models.Register
вместо строки. Измените свой код на это:
using (var db = new RegModelContext())
{
return View(db.Registrant.ToList());
}
Имейте в виду, что это возвращает все Register
элементы в вашей базе данных. Это может быть много данных. Может быть, вы хотите внедрить пейджинг или другой тип фильтрации, чтобы убедиться, что все работает как положено.