我有一个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" />
任何帮助,非常感谢。
与2012数据库一起使用的代码有'connectionString ='data source =(localdb)\ ** v11.0 **'。您可以从包含的内容中了解到SQL Server 2012是版本11. SQL Server 2014是版本12.此外,我会将' '更改为' –
Jason