c# 未能加载文件或程序集"mysql.data,SQLite的C#,.NET应用自适应32位/64位系统(未能加载文件或程序集“System.Data.SQLite.dll)...

本文介绍了在C#应用中遇到SQLite未能加载文件或程序集的错误,特别是在32位和64位系统之间切换时。通过分析问题原因,指出解决方案在于使用非混合编译的System.Data.SQLite二进制包,并将其与SQLite.Interop.dll一同部署,确保应用能在任意CPU平台上运行。
摘要由CSDN通过智能技术生成

SQLite异常报错

e5e98b781ca19af2def09e962e246790.png

其他信息: 未能加载文件或程序集“System.Data.SQLite, Version=1.0.103.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139”或它的某一个依赖项。试图加载格式不正确的程序。

System.BadImageFormatException: 未能加载文件或程序集“System.Data.SQLite.dll”或它的某一个依赖项。 不是有效的 Win32 应用程序。 (异常来自 HRESULT:0x800700C1)

以上报错都是由于没有正确的引用System.Data.SQLite.dll

在网上找了很多信息,都是很长的文字,有的说安装32位或64位的SQLite环境,这个确实管用,但是安装时还要安装SQLite 32位或64位环境,这个我很不喜欢,今天终于把这个问题解决了 并且同时适用 32位和64位系统

我是一个理科生,不太喜欢长篇文字,喜欢简单

如果一个.NET应用要自适应32位/64位系统,只需要在项目的“目标平台”设置为“Any CPU”。但是如果应用中使用了SQLite,情况就不同了。

SQLite的.NET开发包来自是System.Data.SQLite,完成兼容ADO.NET接口,也提供了Linq和Entity Framework 6实现。但这不重要,重要的是System.Data.SQLite是由两部分代码组成的,一部分是非托管的C++代码实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值