gpt4 book ai didi

sqlite - System.Data.SQLite 和 SubSonic 3 : Works great in VS2008, 但不在 VS2010 中

转载 作者:行者123 更新时间:2023-12-03 17:39:14 24 4
gpt4 key购买 nike

去年,我在 VS2008 项目中非常成功地使用了 SubSonic 3 和 SQLite,并对结果非常满意。就在最近,我尝试在 VS2010 项目中设置 SubSonic 3 和 SQLite,并在尝试实例化新的 SimpleRepository 时遇到内部异常:

The type initializer for 'System.Data.SQLite.SQLiteFactory' threw an exception

为了确保我没有发疯,我在 VS2008 中尝试了完全相同的代码和 app.config 文件,没有问题。奇怪!

目前,我正在使用 SubSonic 3.0.0.4 和 x64 版本的 System.Data.SQLite 1.0.73.0 (3.7.6.3)(尽管我也尝试了 32 位版本。)我添加了两个 DLL 作为引用并将“复制本地”设置为 TRUE。

我的 App.Config 如下所示:

  <system.data>
<DbProviderFactories>
<remove invariant="System.Data.SQLite" />
<add name="SQLite Data Provider" invariant="System.Data.SQLite" description=".Net Framework Data Provider for SQLite"
type="System.Data.SQLite.SQLiteFactory, System.Data.SQLite" />
</DbProviderFactories>
</system.data>

<connectionStrings>
<add name="myDatabase" connectionString="Data Source=C:\DB\mydatabase.db3" providerName="System.Data.SQLite"/>
</connectionStrings>

我的代码如下所示:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using SubSonic.Repository;

namespace SubSonicSqliteTestConsole
{
class Program
{
static void Main(string[] args)
{
var repo = new SimpleRepository("myDatabase", SimpleRepositoryOptions.RunMigrations);
}
}
}

有什么想法吗?

最佳答案

我正在将 SubSonic 3 与 Visual Studio 2010 和 SQLite 1.0.66 一起使用,并且它可以工作。但是,您必须做一些事情:

  • 您的应用程序必须是 x86(不是 AnyCPU),否则您会在 64 位计算机上收到 BadImageFormatException
  • 您必须将目标框架从“Framework 4.0 Client Profile”更改为“Framework 4.0”
  • 您必须将其添加(或修改)到您的 app.config 文件中。如果 useLegacyV2RuntimeActivationPolicy 标志设置为 true,SQLite 将无法工作

    <startup useLegacyV2RuntimeActivationPolicy="true">
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
    </startup>
  • 我的工厂初始化代码如下所示(它包括版本和 PublicKeyToken)。我从我的开发机器上的 machine.config 文件中获得了此设置,我在该文件中运行了设置,并选择将 SQLite 集成到 Visual Studio 2010(来自 All Programs\SQLite 文件夹)。该文件位于@%WinDir%\Microsoft.NET\Framework\<FrameworkVersion>\CONFIG

    <system.data>
    <DbProviderFactories>

    <remove invariant="System.Data.SQLite" />
    <add name="SQLite Data Provider" invariant="System.Data.SQLite"
    description=".Net Framework Data Provider for SQLite"
    type="System.Data.SQLite.SQLiteFactory, System.Data.SQLite, Version=1.0.66.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139" />

    </DbProviderFactories>
    </system.data>
  • 我的连接字符串在路径中包含斜杠而不是反斜杠,并且包含版本

    <connectionStrings>
    <add name="connectionstringname"
    connectionString="Data Source=c:/temp/mydatabase.db;Version=3;"
    providerName="System.Data.SQLite"/>
    </connectionStrings>

希望有帮助。

更新:我看到您使用的是 x64 版本的 SQLite,因此请忘记第一个提示。但我留下它,也许对其他人有帮助。

关于sqlite - System.Data.SQLite 和 SubSonic 3 : Works great in VS2008, 但不在 VS2010 中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6380961/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com