0

データベースがシードされていない理由を確認するために数分間探した後、we.config ファイルに次のメッセージが見つかりました。

完全なメッセージ リストは次のとおりです。

メッセージ 1 要素 'entityFramework' のスキーマ情報が見つかりませんでした。

メッセージ 2 要素 'defaultConnectionFactory' のスキーマ情報が見つかりませんでした。

メッセージ 3 at'type' のスキーマ情報が見つかりませんでした。

今、私は MVC に非常に慣れていません。これは、私がこれまでに作成した最初のアプリケーションです。私が構築したモデルからデータベースを作成するために利用可能な Code First Technologies を利用したいと考えています。

私が作成したモデルの例を次に示します。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations.Schema;
using System.ComponentModel;
using System.Data.Entity;
using System.ComponentModel.DataAnnotations;

namespace TNTMVC.Models.UECDECZA.BaseTables
{
public class Actions
{
    [Key]
    public int ActionID { get; set; }
    [Timestamp]
    public DateTime ActionDateCreated { get; set; }
    [Required]
    [DefaultValue(true)]
    public bool ActionActive { get; set; }
    [Required]
    public string ActionName { get; set; }
    [Required]
    [DefaultValue(true)]
    public bool ActionRequiresComponents { get; set; }
    [Required]
    [DefaultValue(1000)]
    public int ActionListOrder { get; set; }
}
}

次に、このような DB コンテキスト クラスを作成しました。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using TNTMVC.Models.UECDECZA.BaseTables;
using TNTMVC.Models.UECDECZA.DataTables;


namespace TNTMVC.Models.UECDECZA
{
public class UecdeczaContext : DbContext
{
    public DbSet<Actions> Actions { get; set; }
    public DbSet<Application> Application { get; set; }
    public DbSet<Area> Area { get; set; }
 }
 }

そして、ここに私の 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.4.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
</configSections>
<connectionStrings>
<add name="ApplicationServices" connectionString="data source=.\SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true" providerName="System.Data.SqlClient" />
<add name="UecdeczaContext" connectionString="Data Source=.\SQLExpress;Integrated Security=True" providerName="System.Data.SqlClient" />
</connectionStrings>
<appSettings>
<add key="webpages:Version" value="1.0.0.0" />
<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>
  <membership>
  <providers>
    <clear />
    <add name="AspNetSqlMembershipProvider" type="System.Web.Security.SqlMembershipProvider" connectionStringName="ApplicationServices" enablePasswordRetrieval="false" enablePasswordReset="true" requiresQuestionAndAnswer="false" requiresUniqueEmail="false" maxInvalidPasswordAttempts="5" minRequiredPasswordLength="6" minRequiredNonalphanumericCharacters="0" passwordAttemptWindow="10" applicationName="/" />
   </providers>
  </membership>
  <profile>
  <providers>
    <clear />
    <add name="AspNetSqlProfileProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="ApplicationServices" applicationName="/" />
   </providers>
  </profile>
  <roleManager enabled="false">
  <providers>
    <clear />
    <add name="AspNetSqlRoleProvider" type="System.Web.Security.SqlRoleProvider" connectionStringName="ApplicationServices" applicationName="/" />
    <add name="AspNetWindowsTokenRoleProvider" type="System.Web.Security.WindowsTokenRoleProvider" applicationName="/" />
    </providers>
  </roleManager>
  <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" />
    <add namespace="System.Data.Entity" />
  </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>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework">
   <parameters>
    <parameter value="Data Source=.\SQLEXPRESS; Integrated Security=True;      MultipleActiveResultSets=True" />
    </parameters>
 </defaultConnectionFactory>
 </entityFramework>
</configuration>

これは成功したモデルの実装であると思われますよね? しかし、まったく機能していないようです。それは私のデータベースをシードしておらず、機能していません:(

また、ASP フォーラムで同じ質問をしました: My ASP Forum Question

4

1 に答える 1

0

Seed() メソッドを呼び出している初期化子 (デフォルトのもの以外) がないようです。詳細については、シードに関する Julia Lerman のブログ投稿を参照してください。次のようなものが必要です:

public class UecdeczaInitializer : DropCreateDatabaseIfModelChanges<UecdeczaContext >
{
    protected override void Seed(UecdeczaContext context)
    {
        new List<Actions>
        {
            new Actions
                {
                    ActionName = "My action name"
                }
            }
        }.ForEach(b => context.Blogs.Add(b));
       base.Seed(context);  }
}

Actions エンティティをシードするために、そこにさらにプロパティを追加する必要があるかもしれませんが、それが基本的な考え方です。

于 2012-08-20T11:25:02.020 に答える