【问题标题】:How can I create a user-defined function in SQLite?如何在 SQLite 中创建用户定义的函数?
【发布时间】:2011-12-13 14:30:13
【问题描述】:

我正在用 android 开发一个应用程序,我需要在 sqlite 中创建一个 udf。是否可以在 sqlite 中创建它?如果是,该怎么做?

【问题讨论】:

  • 顺便说一句 - 为什么不用附加功能重新编译 sqlite ?
  • programering.com/a/MDO0ADMwATU.html(使用 SQLiteOpenHelper)上有一个很好的描述如何在 Java 中完成此操作,而无需使用 NDK 编译 SQLite C 模块。

标签: android sqlite user-defined-functions


【解决方案1】:

SQLite 不像 Oracle 或 MS SQL Server 那样支持用户定义的函数。对于 SQLite,您必须在 C/C++ 中创建一个回调函数并使用 sqlite3_create_function 调用连接该函数。

不幸的是,Android 的 SQLite API 不允许通过 Java 直接调用 sqlite3_create_function。为了让它工作,您需要将SQLite C libraryNDK 一起编译。

如果您仍然感兴趣,请阅读2.3 User-defined functions...

下面是如何创建一个查找字符串第一个字节的函数。

static void firstchar(sqlite3_context *context, int argc, sqlite3_value **argv)
{
    if (argc == 1) {
        char *text = sqlite3_value_text(argv[0]);
        if (text && text[0]) {
          char result[2]; 
          result[0] = text[0]; result[1] = '\0';
          sqlite3_result_text(context, result, -1, SQLITE_TRANSIENT);
          return;
        }
    }
    sqlite3_result_null(context);
}

然后将函数附加到数据库。

sqlite3_create_function(db, "firstchar", 1, SQLITE_UTF8, NULL, &firstchar, NULL, NULL)

最后,在sql语句中使用函数。

SELECT firstchar(textfield) from table

【讨论】:

  • 一个非常简洁的例子。但是,您选择编写的示例将返回第一个字节,而不是 UTF-8 字符串的第一个字符,这不一定是有效的 Unicode 值。以防有人逐字复制。
  • @Michael 对于我的一个项目...我下载了 NDK,通过 Eclipse 启用了对项目的本机支持,添加了 sqlite.c。我将自定义函数添加到一个 separate 文件而不是 sqlite.c。尽量不要修改 sqlite.c 文件。请记住,本机 sqlite 库与 Java sqlite 库不同。因此,在本机 C/C++ 代码中定义的任何 sqlite 函数都将在 Java 中可用。
  • @jojaba 你能告诉我你把sqlite3_create_function(db, "firstchar", 1, SQLITE_UTF8, NULL, &firstchar, NULL, NULL)声明放在哪里(在sqlite.c文件中;如果没有,你如何在一个单独的文件中声明db)?
  • @shashwat 在来自 sqlite.c 的单独 C 文件中添加 sqlite3_open。如何添加 C 文件,stackoverflow.com/a/6672422/424124。 SQLite 管道,sqlite.org/cintro.html。您将使用 NDK 将本机方法导出到 Java。
  • @user1404930 您需要使用 JNI/NDK。此答案中有几个链接可以帮助您入门。网上有很多例子说明如何从 Java 与 C 交互,反之亦然。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-01-07
  • 2010-10-02
  • 1970-01-01
  • 1970-01-01
  • 2019-08-16
  • 2015-02-06
相关资源
最近更新 更多