Я разрабатываю приложение в android, и мне нужно создать udf в sqlite. Можно ли создать его в sqlite? И если да, как это сделать?
Как создать пользовательскую функцию в SQLite?
Ответ 1
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
Ответ 2
Недействительно - см. комментарии
Это должно быть возможно с SQLiteCustomFunction из Android sdk 17, который предоставляет вам обратный вызов в Java-коде.
Добавьте метод addCustomFunction в SQLiteDatabase.
Но я должен сказать, что у меня нет опыта с ним.