.NET Framework 4.8 + Microsoft.Data.Sqlite 报 Library e_sqlite3 not found

.NET Framework 4.8 + Microsoft.Data.Sqlite 报 Library e_sqlite3 not found

具体移步:我的博客

提出问题

最近在 .NET Framework 4.8 下使用 Microsoft.Data.Sqlite 时,运行程序报错:

复制代码
System.Exception: "Library e_sqlite3 not found"

即便安装了 Microsoft.Data.Sqlite 和 SQLitePCLRaw.bundle_e_sqlite3,程序仍找不到 DLL。下面是完整排查和解决方案。

问题原因

  1. native DLL 没部署到输出目录 SQLitePCLRaw.bundle_e_sqlite3 只是包装
  2. 真正提供 DLL 的是 SQLitePCLRaw.lib.e_sqlite3
  3. 传统 .NET Framework 项目不会自动把 DLL 复制到:
    bin\x64\Debug\runtimes\win-x64/native/e_sqlite3.dll
  4. 平台不匹配,DLL 是 64 位,项目必须 Platform target = x64
  5. 缺少 VC++ 运行时:e_sqlite3.dll 依赖 Microsoft Visual C++ Redistributable x64

NuGet 配置

在 packages.config 中保留关键包:

复制代码
<package id="Microsoft.Data.Sqlite" version="6.0.15" targetFramework="net48" />
<package id="SQLitePCLRaw.bundle_e_sqlite3" version="2.1.10" targetFramework="net48" />  
<package id="SQLitePCLRaw.lib.e_sqlite3" version="2.1.10" targetFramework="net48" />

⚠️ 注意:不要混用多个不同版本的 Microsoft.Data.Sqlite,否则可能导致 native DLL 部署失败。

初始化代码

在 Program.cs 的入口 Main() 中最开始调用:

csharp 复制代码
using SQLitePCL;

class Program
{
    static void Main(string[] args)
    {
        Batteries_V2.Init();

        // 你的 Sqlite 相关代码
    }
}

解决步骤(手动拷贝 DLL)

1、找到 e_sqlite3.dll,路径通常在: packages\SQLitePCLRaw.lib.e_sqlite3.2.1.10\runtimes\winx64\native\e_sqlite3.dll

2、拷贝到你的项目输出目录:

Simulated_LoginRegi\bin\x64\Debug

或者按照报错路径创建:

Simulated_LoginRegi\bin\x64\Debug\runtimes\win-x64\native\并放入 e_sqlite3.dll。

3、确认 Platform target = x64

4、安装 VC++ Redistributable x64

✅ 这样程序就可以正常运行。

项目目录结构示例

Simulated_LoginRegi/

├─ packages/

│ └─ SQLitePCLRaw.lib.e_sqlite3.2.1.10/

│ └─ runtimes/win-x64/native/e_sqlite3.dll

├─ bin/

│ └─ x64/Debug/

│ ├─ Simulated_LoginRegi.exe

│ └─ e_sqlite3.dll <-- 手动拷贝的位置

├─ Program.cs

├─ Simulated_LoginRegi.csproj

└─ packages.config

总结

根因:.NET Framework 4.8 传统项目不会自动复制 e_sqlite3.dll

解决方法:手动拷贝 DLL + 调用 Batteries_V2.Init() + x64 平台 + 安装 VC++ Redistributable

这是在 .NET Framework 4.8 下使用 Microsoft.Data.Sqlite 的稳定方案

相关推荐
Terrence Shen4 分钟前
demo111
microsoft
互联圈运营观察2 小时前
布局先行、技术深耕:国内端侧AI企业抢滩机器人与具身智能赛道
人工智能·microsoft·机器人
fuquxiaoguang4 小时前
微软Maia 200的“算力经济学”:推理时代的专用芯片如何改写游戏规则
人工智能·microsoft
糖果店的幽灵4 小时前
Part 2: Models(模型)
microsoft·langchain
福尔摩斯·柯南5 小时前
微软Microsoft Office 95/97/2000/xp/2003/2007/2010/2013/2016/2019/2021/2024全系列
microsoft
我是唐青枫5 小时前
C#.NET YARP + OpenTelemetry:网关链路追踪实战
开发语言·c#·.net
德宏大魔王(AI自动回关)7 小时前
从文字应答到具身交互:AI 交互体验的全新进化
microsoft
余衫马7 小时前
Microsoft Semantic Kernel 实战:使用内核参数实现一个简单的对话机器人
人工智能·microsoft·ai·agent·智能体
IT策士8 小时前
Django 从 0 到 1 打造完整电商平台:使用 Django 消息框架与用户权限初步
数据库·django·sqlite
步步为营DotNet8 小时前
深入.NET 11:.NET Aspire 在云原生资源编排与管理的卓越实践
云原生·.net