2015-11-28 2 views
1

Может кто-нибудь объяснить, как получить доступ к базе данных, которую изменяют миграции? Я продолжаю делать миграции и возвращаться назад, но я не знаю, какая база данных будет изменена. Я открываю проводник объектов SQL и обновляюсь и ничего не вижу там, открываю Server Explorer и отключает все подключения, и каким-то образом мои миграции по-прежнему применяются. Что, черт возьми, не так с VS2015? Это я или программное обеспечение не работает правильно?Entity Framework Миграции, которые не применяются вообще

Specify the '-Verbose' flag to view the SQL statements being applied to 

the target database. 
Applying explicit migrations: [201511282210132_Initial]. 
Applying explicit migration: 201511282210132_Initial. 
Running Seed method. 
PM> update-database -target:0 
Specify the '-Verbose' flag to view the SQL statements being applied to the target database. 
Reverting migrations: [201511282210132_Initial]. 
Reverting explicit migration: 201511282210132_Initial. 
PM> Update-Database 
Specify the '-Verbose' flag to view the SQL statements being applied to the target database. 
Applying explicit migrations: [201511282210132_Initial]. 
Applying explicit migration: 201511282210132_Initial. 
Running Seed method. 
PM> update-database -target:0 
Specify the '-Verbose' flag to view the SQL statements being applied to the target database. 
Reverting migrations: [201511282210132_Initial]. 
Reverting explicit migration: 201511282210132_Initial. 
PM> update-database -target:0 
Specify the '-Verbose' flag to view the SQL statements being applied to the target database. 
Target database is already at version 0. 
PM> 

Кто-то сказал мне, что если миграциях получить применяется, то это означает, что VS2015 успешно модифицировать базу данных, но это не похоже, дело вообще.

Может что-то не так с моими конфигурационными файлами:

<?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=301879 
--> 
<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=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" /> 
</configSections> 
<connectionStrings> 
    <add name="DefaultConnection" connectionString="Server=DESKTOP;Database=API;Trusted_Connection=True;" 
     providerName="System.Data.SqlClient" /> 
</connectionStrings> 
<appSettings></appSettings> 
<system.web> 
    <compilation debug="true" targetFramework="4.5" /> 
    <httpRuntime targetFramework="4.5" /> 
</system.web> 
<system.webServer> 
    <handlers> 
    <remove name="ExtensionlessUrlHandler-Integrated-4.0" /> 
    <remove name="OPTIONSVerbHandler" /> 
    <remove name="TRACEVerbHandler" /> 
    <add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" /> 
    </handlers> 
</system.webServer> 
<runtime> 
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> 
    <dependentAssembly> 
     <assemblyIdentity name="System.Web.Helpers" publicKeyToken="31bf3856ad364e35" /> 
     <bindingRedirect oldVersion="1.0.0.0-3.0.0.0" newVersion="3.0.0.0" /> 
    </dependentAssembly> 
    <dependentAssembly> 
     <assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" /> 
     <bindingRedirect oldVersion="1.0.0.0-5.2.3.0" newVersion="5.2.3.0" /> 
    </dependentAssembly> 
    <dependentAssembly> 
     <assemblyIdentity name="System.Web.WebPages" publicKeyToken="31bf3856ad364e35" /> 
     <bindingRedirect oldVersion="1.0.0.0-3.0.0.0" newVersion="3.0.0.0" /> 
    </dependentAssembly> 
    </assemblyBinding> 
</runtime> 
<system.codedom> 
    <compilers> 
    <compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:6 /nowarn:1659;1699;1701" /> 
    <compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:14 /nowarn:41008 /define:_MYTYPE=\&quot;Web\&quot; /optionInfer+" /> 
    </compilers> 
</system.codedom> 
<entityFramework> 
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" /> 
    <providers> 
    <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" /> 
    </providers> 
</entityFramework> 
</configuration> 

Кроме того, нет никаких файлов App_Data. Кто-то сказал мне, что должен быть файл mdf, но я ничего не могу найти. Возможно, что-то не так с VS2015. Другое дело, что я пытаюсь сделать учебник, сделанный в VS2013 с VS2015.

+0

Ваша строка соединения говорит 'Server = DESKTOP; Database = API', так что вы должны проверить' базы данных API' на 'DESKTOP' сервере. –

+0

нет таблицы, которая создается, это странная вещь. Из-за этого я ударился головой о стену. Это не имеет никакого смысла! В папке таблицы мы видим только папку System Tables и FileTables без другой таблицы, кроме dbo.sysdiagram. Я попытался сделать то же самое, не создавая db a priori, и он вообще не работает. Если я создам его перед выполнением миграций, абсолютно никаких изменений. Я не знаю, что случилось с VS2015. – jarvan

+0

Даже если вы запустите команду «update-database»? Можете ли вы опубликовать свою миграцию «Начальная»? –

ответ

2
<connectionStrings> 
    <!-- Original Connection String --> 
    <!-- 
    <add name="DefaultConnection" connectionString="Data Source=(LocalDb)\v11.0; 
     Initial Catalog=aspnet-AspnetIdentitySample-20130627083537_2;Integrated Security=True" 
     providerName="System.Data.SqlClient" /> 
    --> 
    <!-- New Connection String --> 
    <add name="MyConnectionString" connectionString="Data Source=(LocalDb)\v11.0; 
     Initial Catalog=MyAspnetIdentitySample_1;Integrated Security=True" 
     providerName="System.Data.SqlClient" /> 
    </connectionStrings> 

Хорошо, проблема в том, что я не установил connectionString в свой конструктор. По какой-то причине в учебнике он работал без него, но похоже, что ASP.NET сильно изменилась с тех пор, поэтому вы, вероятно, должны сделать это, если в итоге у вас будет та же проблема, что и я.

public class MyDbContext : DbContext{ 
    public MyDbContext() : base("MyConnectionString") { } 
} 

После этого, просто откатить все миграции, удалите папку миграции и написать в консоли управления пакетами:

>Enable-Migrations 
>Add-Migration Initial 
>Update-Database 

Эти 3 команды должны создать базу данных.

0

Я использовал следующий подход для решения проблемы. Открыть пакет яслей консоли и следующей командой

1> Enable-Миграция уже включить -> Add-Migration Initial завершено 3> Update-Database Укажите '-Verbose' флага для просмотра SQL ... ...

решение 1: - у меня было открыть базу данных и удалить __MigrationHistory и выполнить команду обновления базы данных-команду

решение 2: Если первое решение не работать, а затем удалить всю таблицу из базы данных и запустить команду update-database в консоли управления ваши данные со структурой будут доступны.

Это может решить вашу проблему.

Благодаря Самир Bahad

Смежные вопросы