web-dev-qa-db-ja.com

SQLiteでユーザー定義関数を作成するにはどうすればよいですか?

Androidでアプリケーションを開発しています。sqliteでudfを作成する必要があります。sqliteで作成することはできますか?はいの場合、これを行う方法はありますか?

34
Mustafa Güven

SQLiteは、OracleまたはMS SQL Serverのようにユーザー定義関数をサポートしていません。 SQLiteの場合、C/C++でコールバック関数を作成し、 sqlite3_create_function 呼び出しを使用して関数をフックする必要があります。

残念ながら、AndroidのSQLite APIはsqlite3_create_function Javaから直接呼び出します。動作させるには、 [〜#〜] ndk [〜#〜]SQLite Cライブラリ をコンパイルする必要があります。

そしてまだ興味があるなら、読んでください 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
70
tidwall

無効-コメントを参照

SQLiteCustomFunction from Android SDK 17は、Javaコードでコールバックを提供します。

SQLiteDatabaseaddCustomFunctionメソッドで追加します。

しかし、私はそれを経験していないと言わなければなりません。

0