将项目从 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 查询将WP从“http”切换到“https”以进行SSL配置