- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我能够在我的开发箱上构建和执行我的 Winforms 应用程序,但是当我尝试在另一个干净的箱子(虚拟机)上运行我的应用程序时,我遇到了这个错误。
Application: MyApp.exe
Framework Version: v4.0.30319
Description: The process was terminated due to an unhandled exception.
Exception Info: System.DllNotFoundException
at System.Data.SQLite.UnsafeNativeMethods.sqlite3_config_none(System.Data.SQLite.SQLiteConfigOpsEnum)
at System.Data.SQLite.SQLite3.StaticIsInitialized()
at System.Data.SQLite.SQLiteLog.Initialize()
at System.Data.SQLite.SQLiteConnection..ctor(System.String, Boolean)
at System.Data.SQLite.SQLiteConnection..ctor()
at DittoSql.SQL..ctor()
at MyApp.Program..cctor()
Exception Info: System.TypeInitializationException
at MyApp.Program.Main(System.String[])
我使用 Nuget 将 SQLite 添加到我的项目中。
遗憾的是,事件查看器日志没有提供系统找不到的DLL。我做了研究,发现的一件事是 .Net 兼容性。我在 4.6.2,SQLite v1.08 不支持,所以我降级到 .Net 4.6,已列出。
两台机器都运行带有所有最新更新的 Windows 10 X64。
这是显示文件的应用程序文件夹的屏幕截图。
更新
根据@Plutonix 的评论,这里是显示对我的项目的引用的屏幕截图。缺少 System.Data.SQLite.Core
,其中包含互操作文件。每个 .Net 版本和操作系统类型都有不同的版本,所以我不能只浏览 packages 文件夹中的文件夹,除此之外这是一个可怕的 hack。应该有一种干净的方式来添加引用。
作为记录,我简要地想到了那个文件,但我没有看到它,或者核心和计算版本 1.08 没有使用它,但我猜它确实有。
注意:我将 SQLite.Interop.dll
文件手动复制到 VM 并加载了项目。 Procman
没有那么有用,也许信息太多了,尽管我过滤掉了除我的应用程序以外的所有内容。无论如何,问题是如何获得对 SQLite 核心的引用。
更新 2
从 NuGet 中卸载所有 sqlite 组件然后重新安装 SQLite 不会在项目中添加对核心的引用,这很烦人。
更新 3
This SO文章(在答案中)说明了问题。基本上,无论出于何种困惑的原因,NuGet 都正确地“需要”核心,但随后却什么都不做。因此,NuGet 不会分发所需的文件。我看到了“复制”X86/X64 文件夹等的答案。
首先,我将其命名为 NuGet SQLite 程序包中的严重缺陷/错误。是的,如果您知道答案,那么这个问题有点像引用问题的重复,但我不知道,所以不是。我从未在互操作 DLL 上收到任何错误消息。
最佳答案
(我希望有人能提出更好的答案,因为我的答案是 hack。)
在出现真正优雅和适当的解决方案之前,我想到了这个解决方法。将以下内容添加到项目设置的 Build Events` 选项卡上的 Post-build event command line。
任何使用我的命令行的人显然必须将 net46
设置为项目中使用的 .Net 版本并将 SQLite 版本设置为 1.0.108.0
版本将是。
robocopy "$(ProjectDir)\..\packages\System.Data.SQLite.Core.1.0.108.0\build\net46\$(PlatformName)" $(TargetDir) SQLite.Interop.dll
这是截图。
注意
我还想到了包含 DLL 的项目文件的条件逻辑,但这比简单的 RoboCopy 更复杂。
关于c# - SQLite.SQLite3 : Exception System. DllNotFoundException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51546962/
我有一个带有帮助页面的 Web API 2 项目,该项目在本地运行良好,但当我将其推送到 Azure 时抛出此错误: Method not found: 'System.String System.S
我有两台服务器,但通常运行相同的设置 - IIS、SQL Server 等。一台给我这个错误,另一台没有。我从 Visual Studio 向两者发布相同的代码。 它们都在运行 .NET CLR Ve
System.out声明为 public static final PrintStream out。 但是你可以调用System.setOut()重新分配它。 嗯?如果它是 final,这怎么可能?
System.out被声明为 public static final PrintStream out。 但是您可以调用System.setOut()重新分配它。 嗯?如果是 final,这怎么可能?
我有这个 linq 查询: private void GetReceivedInvoiceTasks(User user, List tasks) { var areaIds = user.A
我有一个 MonoTouch 应用程序,当我为设备编译它时,出现以下错误: Error MT2002: Can not resolve reference: System.Boolean System
您好,我有一个名为 DailyVisitReport 的 View 。在该 View 中,我有两个名为 FromDate 和 toDate 的字段。如果我选择 FromDate 和 ToDate 取决
是否可以从 ObjectContext 对象中读取元组列表? 我在存储过程中有类似这样的数据库查询 SELECT T.Id as Item1, -- this is guid T.Wo
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我有一个方法可以从数据读取器的数据中生成类类型列表。 if (datareader != null && datareader .HasRows) { Dictionary pDict= GetP
我有一些旧的 C++ 代码,它们使用 stdio 进行输入和输出。该代码还通过 fork 生成新进程。它将 stdio 重新映射到每个新进程,以便每个 session 获取其各自的数据。 我正在考虑使
我的应用程序可以很好地构建/链接/部署到模拟器,但我只是第一次尝试将应用程序构建/部署到真实设备,并且链接器失败。 我不使用 System.Console或 ConsoleColor在我的应用程序的任
主要是我很好奇。 我们有一个名为 Unit 的对象在我们的代码库中 - 代表桥梁或道路的组件。在我们的例子中,看到带有 Unit 的 ReactiveUI 命令可能会模棱两可。作为声明中的泛型之一。
我试图将Object变量转换为StreamWriter。但是,它不起作用。有什么错? StreamWriter file = (StreamWriter) myObject; 最佳答案 myObjec
为什么以下不编译? using System; using System.Linq; using System.Linq.Expressions; public static class Extens
我正在使用 Visual Studio Community 2015 开发面向 .NET 4.5 的 Visual Basic 应用程序.我没有编写应用程序,所以我使用 NuGet 添加了所有缺失的依
我刚刚开始使用 powershell,我正在制作一个非常简单的加密功能。我想获取字符串中的每个字符,将其转换为 int 并添加一个选定的数字,然后将其转换回一个字符。 这工作正常: function
一些使用我的应用程序的人似乎变得越来越 System.MissingMethodException: Method not found: 'System.Object System.Windows.T
我是 C# 和实体的新手 我想知道是否有人在这里帮助我。我选择了哪个返回我的 customerid,所以我想将它作为参数传递给我的构造函数,我的构造函数参数类型是 guid 但我的选择类型不同,我不知
我是一名优秀的程序员,十分优秀!