1

我正在使用 sqlite fts5 创建一个虚拟表,并且出现以下错误消息: SQL Logic error no such module: FTS5. 下面是我的代码: 在 VS 2017 中使用包管理器 我已经下载了 SQLite 和 SQLite FTS5。

    private static void CreateReport()
    {
        try
        {
            using (SQLiteConnection sqliteConnection = new SQLiteConnection(DataSources.LocalConnectionString()))
            {
                sqliteConnection.Open();
                sqliteConnection.EnableExtensions(true);
                string commandText = "CREATE TABLE IF NOT EXISTS JReport(JRId INTEGER PRIMARY KEY, IDId INTEGER, CaseId INTEGER, BoxName TEXT, JRText TEXT, JRFormatted TEXT)";
                string commandText1 = "CREATE VIRTUAL TABLE IF NOT EXISTS DReport USING FTS5(JRId, CaseId, BoxName, CONTENT = 'JReport', CONTENT_ROWID = 'JRId')";
                string commandText2 = "CREATE TRIGGER DocRepo AFTER INSERT ON JReport BEGIN INSERT INTO DReport(RowId, JRId, CaseId, BoxName) VALUES(NEW.JRId, NEW.CaseId, NEW.BoxName) END";
                using (SQLiteCommand sqliteCommand = new SQLiteCommand(commandText, sqliteConnection))
                {
                    sqliteCommand.ExecuteNonQuery();
                    sqliteCommand.Dispose();
                }
                using (SQLiteCommand sqliteCommand = new SQLiteCommand(commandText1, sqliteConnection))
                {
                    sqliteCommand.ExecuteNonQuery();
                    sqliteCommand.Dispose();
                }
                using (SQLiteCommand sqliteCommand = new SQLiteCommand(commandText2, sqliteConnection))
                {
                    sqliteCommand.ExecuteNonQuery();
                    sqliteCommand.Dispose();
                }
                sqliteConnection.Close();
            }
        }
        catch (Exception ex)
        {
            MessageBoxEx.Show("An error has occurred while creating the Report table, the original error is: " +
                ex.Message, "Report", MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }
4

1 回答 1

1

SQL 逻辑错误没有这样的模块:FTS5。

就像错误消息说的那样,您的 sqlite3 库没有 FTS5 模块。构建库时,它可能未配置为将其作为内置库包含在内,因为默认情况下未启用它。它可能已由配置和构建您正在使用的库的任何人作为可动态加载的模块提供。或不。

就个人而言,我总是在我使用的任何程序中包含 sqlite3.c 的副本,以避免依赖外部依赖项,因此您可以确保始终使用具有您想要使用的所有功能的版本当下。不知道你必须在 C# 中做什么才能使用你自己的本地实例,但我相信有办法。

将FTS5构建到 sqlite3 或作为可加载模块的说明。

于 2018-07-31T22:06:09.497 回答