Как я могу создать пользовательскую функцию в SQLite?

33

Я разрабатываю приложение в android, и мне нужно создать udf в sqlite. Можно ли создать его в sqlite? И если да, как это сделать?

  • 1
    Кстати, почему бы не перекомпилировать sqlite с дополнительными функциями?
  • 0
    Существует прекрасное описание того, как этого добиться в Java, без необходимости компилировать модуль SQLite C с помощью NDK, по адресу programering.com/a/MDO0ADMwATU.html (используя SQLiteOpenHelper).
Теги:
user-defined-functions

2 ответа

63
Лучший ответ

SQLite не поддерживает пользовательские функции так, как это делает Oracle или MS SQL Server. Для SQLite вы должны создать функцию обратного вызова в C/С++ и подключить эту функцию, используя вызов sqlite3_create_function.

К сожалению, SQLite API для Android не разрешает вызов sqlite3_create_function напрямую через Java. Чтобы заставить его работать, вам нужно скомпилировать библиотеку SQLite C с помощью NDK.

И если вам все еще интересно читать 2.3 Пользовательские функции...

Здесь, как создать функцию, которая находит первый байт строки.

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
  • 10
    Прекрасный пример. Однако пример, который вы выбрали для записи, вернет первый байт, а не первый символ строки UTF-8, которая не обязательно является допустимым значением Unicode. На случай, если кто-нибудь скопирует это дословно.
  • 1
    @Michael Для одного из моих проектов ... Я скачал NDK, включил поддержку Native для проекта через Eclipse, добавил sqlite.c. Я добавил пользовательские функции в отдельный файл, чем sqlite.c. Старайтесь не изменять файл sqlite.c. Помните, что нативная библиотека sqlite отличается от библиотеки Java sqlite. Поэтому любые функции sqlite, определенные в собственном коде C / C ++, не будут доступны в Java.
Показать ещё 16 комментариев
1

Недействительно - см. комментарии

Это должно быть возможно с SQLiteCustomFunction из Android sdk 17, который предоставляет вам обратный вызов в Java-коде.

Добавьте метод addCustomFunction в SQLiteDatabase.

Но я должен сказать, что у меня нет опыта с ним.

  • 4
    Они @hide и недоступны в SDK.
  • 0
    Как заметил @laalto, addCustomFunction недоступна в SDK.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню