2017-04-10 54 views
1

我有一个C#应用程序,我正在尝试使用LocalDB。截至目前,当我启动我的应用程序时,我受到这个错误的迎接。'本地数据库运行时:无法创建命名实例

Cannot create named instance. 

The parameter for the LocalDB Instance API method is incorrect. Consult the 
API documentation. 

我的App.config看起来像这样。

<system.data.localdb> 
    <!-- I saw this on another website, I'm not sure if it's neeed or not.--> 
    <localdbinstances> 
    <add name="MSSQLLocalDB" version="mssqllocaldb" /> 
    </localdbinstances> 
</system.data.localdb> 
<connectionStrings> 
<add name="DiaProdConnection" 
    connectionString="Data Source=(localdb)\MSSQLLocalDB;AttachDbFileName=|DataDirectory|\DatabaseFileName.mdf;Integrated Security=True;MultipleActiveResultSets=True" 
    providerName="System.Data.SqlClient" /> 
</connectionStrings> 
<entityFramework> 
    <defaultConnectionFactory 
     type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" /> 
<providers> 
    <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" /> 
</providers> 

当我运行Sqllocaldb.exe版本,我得到下面的输出。

..> SqlLocalDB.exe versions 
    Microsoft SQL Server 2012 (11.0.3000.0) 
    Microsoft SQL Server 2014 (12.0.4459.0) 
    Microsoft SQL Server 2016 (13.0.1601.5) 

理想情况下,应用程序会启动,当它看到db不存在时,它会创建它。

下面的代码行可以在开发中使用,但是如果我的测试系统上有失败的SQLLocalDB 2014版本,这就是我决定使用新字符串的原因。此外,乡亲们说旧字符串已弃用,并且仅适用于2012年。

<add name="DiaProdConnection" connectionString="data source=(localdb)\v11.0;initial catalog=DiaDb;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework;Connection Timeout=15;Connection Lifetime=0;Min Pool Size=10;Max Pool Size=20;Pooling=true;" providerName="System.Data.SqlClient" /> 

任何帮助,非常感谢。

+0

与2012数据库一起使用的代码有'connectionString ='data source =(localdb)\ ** v11.0 **'。您可以从包含的内容中了解到SQL Server 2012是版本11. SQL Server 2014是版本12.此外,我会将''更改为' Jason

回答

1

SOLUTION:

  1. 清除火灾所有非SQL 2014的LocalDB以上实例的计算机。在撰写本文时,我正在使用SQL-2014版本。

  2. 使App.Config中的EF连接xml看起来像这样。

    <system.data.localdb> 
        <localdbinstances> 
        <add name="MyNamedInstance" version="12.0" /> 
        </localdbinstances> 
    </system.data.localdb> 
    <connectionStrings> 
        <add name="DiaProdConnection" 
         connectionString="Data Source=(localdb)\MyNamedInstance;Initial 
         Catalog=MovieDB;Integrated 
         Security=True;AttachDbFilename=|DataDirectory|MovieDB.mdf" 
         providerName="System.Data.SqlClient" /> 
    </connectionStrings> 
    
  3. 很多例子都会有这个字段| DataDirectory |在他们的连接字符串。不幸的是,他们不会告诉你的是,该字符串不是框架已知的特殊字符串,而是您必须分配和设置自己的变量。为此,我在我的应用程序的入口处调用此代码。

    AppDomain.CurrentDomain.SetData(“DataDirectory”, Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData));

请记住,如果DB存在于系统中但位于不同位置,则连接器将引发错误。

运行

Sqllocaldb.exe i 

应该帮助你查看是否有实例存在,并从那里是否需要被删除,你可以决定。

我很害怕文档对错误有多糟糕,以及整个事情似乎令人厌恶。