将项目从 SQL 切换到 SQLLite

问题描述

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

解决方法

EFCore 有一个 SQLite database provider 可以满足您的需求。您需要注意some limitations,因为 SQLite 没有对某些数据类型的本机支持,并且没有等效的架构或序列概念。

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

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

  • DateTimeOffset
  • Decimal
  • TimeSpan
  • UInt64

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