将项目从 SQL 切换到 SQLite

Posted

技术标签:

【中文标题】将项目从 SQL 切换到 SQLite【英文标题】:Switch project from SQL to SQLLite 【发布时间】:2021-07-02 21:29:43 【问题描述】:

我有基于 SQL DB 实体框架代码优先态度和存储库创建的 .net core 5 web api 项目。 我需要将项目切换到 SQLLite,是否可以切换到 SQLLite,EntityFramework 是否支持?

【问题讨论】:

【参考方案1】:

EFCore 有一个 SQLite database provider,它应该可以满足您的需求。您需要注意some limitations,因为 SQLite 没有对某些数据类型的原生支持,也没有等效的模式或序列概念。

“不受支持”的数据类型仍然可以部分发挥作用,因为您可以存储和检索值,但比较和排序可能会失败,除非您在客户端而不是“在服务器上”运行它们 - 在您的代码中而不是通过 SQL 执行。

受影响的数据类型(根据上面的链接):

DateTimeOffset Decimal TimeSpan UInt64

文章建议在模型构建器中使用值转换器将 Decimal 转换为 double 以允许本地比较和排序。如有必要,可能还有其他方法可以对其他类型执行此操作。

【讨论】:

以上是关于将项目从 SQL 切换到 SQLite的主要内容,如果未能解决你的问题,请参考以下文章

从内存数据库中的 H2 切换到 SQL Server 时出错

将 SQL 查询从关联切换到实例方法

sql 查询将WP从“http”切换到“https”以进行SSL配置

ASP.NET 从 SQL 切换到 Access DB 后,我无法让我的数据源/gridview 正常工作

在从本地迁移到Azure SQL数据库时如何计划生产切换?

在EF6中切换MySQL / SQL Server