10

在我成功使用 SQLite 和 NHibernate 之后,我很高兴将它用于使用 Entity Framework Code First 进行测试。

如果您有一些示例连接字符串并设置演示,那将非常棒,并且可以从我忙碌的一天中节省一点时间。

非常感谢。

编辑:

值得一提的是,在通过 EF“数据上下文”应用 crud 操作时,我在调试过程中遇到了这个错误:

无法确定类型为“System.Data.SQLite.SQLiteConnection”的连接的提供程序名称。

<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="DataContext"
         connectionString="Data Source=:memory:;Version=3;New=True;"
         providerName="System.Data.SQLite"
     />
</connectionStrings>

希望 EF 确实以这种方式与 SQLite 集成。尽管错误消息令人震惊地暗示可能不是。

4

2 回答 2

6

您需要使用程序集限定名称:

<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" />
于 2011-03-26T05:18:55.673 回答
5

Code First 应该适用于任何 ADO.NET 3.5 级别的提供程序(它们实现实体框架功能)。

支持 4.0 的提供程序还添加了 DeleteDatabase/CreateDatabase/DatabaseExists 功能。

除了这些之外,Code First 不需要额外的提供程序功能。

发生的情况是它查看 Connection 的类型,然后尝试将其映射回提供者及其提供者工厂,以便它可以创建它需要的所有其他内容。

值得检查以确保您的 GAC 中安装了支持 3.5 级功能的最新 SQLLite 提供程序。

于 2010-12-29T18:46:50.270 回答