解决.NET Core 2.0+ 使用SQLite出现异常"unable to open database file"

错误内容:

如在项目中使用sqlite,连接字符串为:DataSource=Weather.db,在Asp.NET Core 中有如下错误 .net core SqliteException: SQLite Error 14: 'unable to open database file',在.Net Core Console App中可能会报错No Such Table 'xxx',可能都是sqlite连接字符串的相对路径未被识别导致的

解决方案:

一、最简单的办法,把路径设置为绝对路径即可如:“C:/xx/xx/xx/Weather.db”,不过这样一来就缺乏灵活性,接下来有更好的办法。

二、使用使用.net core sdk提供的默认使用SQLite的项目模板创建一个项目,命令如下:

创建模板,-au Individual表示使用身份验证,-uld是使用Local DB,如果参数是False,则使用SQLite,如果为True,则使用SQL Server LocalDB

dotnet new mvc -au Individual -uld false --name SQLiteCore

该项目中也是使用的相对路径DataSource=app.db,但是却没有这个错误,通过和VS创建的项目进行对比,发现项目的startup.cs和program.cs均无特殊设置,但是.csproj文件多了一个配置,如下:

<Project Sdk="Microsoft.NET.Sdk.Web">
  <PropertyGroup>
    <TargetFramework>netcoreapp2.2TargetFramework>
    <UserSecretsId>aspnet-SQLiteCore-EEF36315-16B4-44B9-AFBD-0041D5170A86UserSecretsId>
    <AspNetCoreHostingModel>InProcessAspNetCoreHostingModel>
  PropertyGroup>
  
  
  <ItemGroup>
    <None Update="app.db" CopyToOutputDirectory="PreserveNewest" />
  ItemGroup>

  <ItemGroup>
    <PackageReference Include="Microsoft.AspNetCore.App" />
    <PackageReference Include="Microsoft.AspNetCore.Razor.Design" Version="2.2.0" PrivateAssets="All" />
    <PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="2.2.1" />
  ItemGroup>

Project>

你可能感兴趣的:(.NET,Core,SQLite,.net,Core,sqlite,unable,to,open,database,file)