Как интегрировать SQL Server CE с Enterprise Library 5 DatabaseFactory?
Я получаю
"Произошла ошибка активации при попытке получить экземпляр типа База данных, ключ" ""
исключение с моим DatabaseFactory.CreateDatabase()
всякий раз, когда я ссылаюсь на базу данных по умолчанию на SQL Server CE
Я попытался проверить, является ли проблема только моей ссылкой.dll, что я смог доказать неправильно, потому что я все еще был в состоянии соединиться с реальной базой данных SQL Server 2008.
Вот мой конфиг:
<configSections>
<section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=5.0.414.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" requirePermission="false"/>
</configSections>
<dataConfiguration defaultDatabase="sqlCEDB"/>
<connectionStrings>
<add name="sqlCEDB"
connectionString="Data Source=|DataDirectory|\sqlCEDB.sdf;Password='somepassword'"
providerName="Microsoft.SqlServerCe.Client.3.5" />
</connectionStrings>
Вот как я создаю экземпляр базы данных:
private Database db;
protected internal Database DB
{
get
{
if (db == null)
db = DatabaseFactory.CreateDatabase();
return db;
}
}
РЕШЕНИЕ
решено изменить свойство конфигурации: providerName="System.Data.SqlServerCe.3.5"
1 ответ
РЕШЕНИЕ
решено изменить свойство конфигурации: providerName="System.Data.SqlServerCe.3.5"
<configSections>
<section name="dataConfiguration"
type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=5.0.414.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
requirePermission="false"/>
</configSections>
<dataConfiguration defaultDatabase="sqlCEDB"/>
<connectionStrings>
<add name="sqlCEDB"
connectionString="Data Source=|DataDirectory|\sqlCEDB.sdf;Password='somepassword'"
providerName="System.Data.SqlServerCe.3.5" />
</connectionStrings>