'本地数据库运行时:无法创建命名实例

时间:2017-04-10 23:47:29

标签: c# .net sql-server localdb

我有一个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不存在时,就会创建它。

以下行在开发中确实有效,但是如果我的测试系统失败了,那么我的测试系统有2014版SQLLocalDB,这就是我决定使用新字符串的原因。此外,人们说旧字符串已被弃用,仅适用于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" />

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:1)

解决方案:

  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(&#34; DataDirectory目录&#34 ;,  Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData));

  4. 请记住,如果数据库存在于系统上但位于不同位置,则连接器将引发错误。

    正在运行

    Sqllocaldb.exe i
    

    应该帮助您查看是否存在实例,然后您可以决定是否需要删除它。

    我对文件在错误方面表现不佳以及整个事情看起来多么令人讨厌感到震惊。