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 элементы в вашей базе данных. Это может быть много данных. Может быть, вы хотите внедрить пейджинг или другой тип фильтрации, чтобы убедиться, что все работает как положено.

Другие вопросы по тегам