Как вы автоматически генерируете SDF в подходе Code First? - PullRequest
3 голосов
/ 03 апреля 2012

Я создал POCO и контекст и добавил EF в свой проект из NuGet (v4.3.1).App.config выглядит для меня немного новым по сравнению с тем, к чему я привык.Там есть этот раздел:

<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework">
  <parameters>
    <!--<parameter value="Data Source=|DataDirectory|Test.sdf; Integrated Security=True; MultipleActiveResultSets=True" />-->
  </parameters>
</defaultConnectionFactory>

Я закомментировал «параметр» и вместо этого добавил фрагмент строки подключения, например, под тегом вверху:

<connectionStrings>
  <add name="CodeFirstExampleContext" connectionString="Data Source=|DataDirectory|Test.sdf;Initial Catalog=CodeFirstExample;integrated security=True" providerName="System.Data.SqlServerCe.4.0" />
</connectionStrings>

Ранее с такой строкой подключения база данных SQL CE получала автоматически.однако сейчас этого не происходит.Вместо этого я получаю следующее исключение:

"Произошла ошибка при получении информации о поставщике из базы данных. Это может быть вызвано тем, что Entity Framework использует неверную строку подключения. Проверьте подробности внутренних исключений и убедитесь, что строка подключенияявляется правильным. "

Внутреннее исключение:

" Поставщик не возвратил строку ProviderManifestToken. "

Вот мои типы POCO и Context:

class Person
{
    [Key]
    public int Id { get; set; }
    public string FName { get; set; }
    public string LName { get; set; }
    public int Age { get; set; }
}


class Context:DbContext
{
    public DbSet<Person> People { get; set; }
}

Я что-то здесь упускаю?

Заранее спасибо!

1 Ответ

0 голосов
/ 03 апреля 2012

Измените строку подключения на:

<connectionStrings> 
  <add name="Context" connectionString="Data Source=|DataDirectory|\Test.sdf"
    providerName="System.Data.SqlServerCe.4.0" /> 
</connectionStrings>

И изменить фабрику соединений по умолчанию:

<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlCeConnectionFactory, EntityFramework">
  <parameters>
    <parameter value="System.Data.SqlServerCe.4.0" />
  </parameters>
</defaultConnectionFactory>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...