我正在使用 EntityFrameworkCore.Sqlite.NetTopologySuite 创建一个空间数据库来存储一个点,但最终将用于线等。我使用空间数据文档作为参考https://docs.microsoft.com/en-us/ef /核心/建模/空间#sqlite。数据需要保存到 Spatialite 数据库中。
浏览完文档后,我已经反映了代码,包括选项构建器(如下)中的“UseNetTopology”,并在类中创建了一个点。
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlite("Filename=TestDb.db", x => x.UseNetTopologySuite());
}
当我尝试使用更新数据库时update-database
收到错误消息:
SQLite Error 1: 'The specified module could not be found.'.
我试图通过创建一个空白项目并从头开始工作来找到问题,但结果出现了同样的错误。
这是整个日志:
'.
at Microsoft.Data.Sqlite.SqliteException.ThrowExceptionForRC(Int32 rc, sqlite3 db)
at Microsoft.Data.Sqlite.SqliteCommand.ExecuteReader(CommandBehavior behavior)
at Microsoft.Data.Sqlite.SqliteCommand.ExecuteNonQuery()
at Microsoft.EntityFrameworkCore.Infrastructure.SpatialiteLoader.Load(DbConnection connection)
at Microsoft.EntityFrameworkCore.Sqlite.Storage.Internal.SqliteRelationalConnection.LoadSpatialite()
at Microsoft.EntityFrameworkCore.Sqlite.Storage.Internal.SqliteRelationalConnection.Open(Boolean errorsExpected)
at Microsoft.EntityFrameworkCore.Storage.Internal.RelationalCommand.Execute(IRelationalConnection connection, DbCommandMethod executeMethod, IReadOnlyDictionary`2 parameterValues)
at Microsoft.EntityFrameworkCore.Migrations.HistoryRepository.Exists()
at Microsoft.EntityFrameworkCore.Migrations.Internal.Migrator.Migrate(String targetMigration)
at Microsoft.EntityFrameworkCore.Design.Internal.MigrationsOperations.UpdateDatabase(String targetMigration, String contextType)
at Microsoft.EntityFrameworkCore.Design.OperationExecutor.OperationBase.Execute(Action action)
SQLite Error 1: 'The specified module could not be found.
'.
我找不到任何其他具有相同问题的帖子。
编辑 19/8/19: 我刚刚创建了一个新的空白项目,通过从 Spatialite 网站安装并使用 SQLite 连接到空间数据库,在没有实体框架的情况下进行测试。我以手动方式收到了同样的错误,所以这可能是 Spatialite 的问题?