SQLite에 사용자 정의 함수를 추가하는 방법


안드로이드 앱을 개발하고 있습니다. SQLite에 함수를 추가하고자 하는데 SQLite에 함수를 새로 정의하여 추가하는 게 가능한가요? 가능하다면 어떻게 해야 하나요?


조회수 123


1 답변


좋아요
0
싫어요
채택취소하기

SQLite는 오라클이나 MS SQL 서버가 제공하는 방식의 사용자 정의 함수를 지원하지 않습니다. SQLite에서는 C/C++로 콜백 함수를 만들어 sqlite3_create_function을 이용하여 연결해야 합니다.

하지만 공교롭게도 안드로이드에서 제공하는 SQLite API는 sqlite3_create_function을 자바에서 바로 지원해주지 않습니다. 따라서 이 경우, NDK를 이용하여 SQLite C 라이브러리를 컴파일해주어야 합니다.

어찌됐든 사용자 정의 함수에 관심이 있으시다면 ...

문자열의 첫번째 문자를 찾아내는 함수를 추가하는 방법을 예시로 보여드리겠습니다.

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)

이렇게 하면 아래와 같이 함수를 사용할 수 있습니다.

SELECT firstchar(textfield) from table
  • 2016년 06월 15일에 작성됨

로그인이 필요한 기능입니다.

Hashcode는 개발자들을 위한 무료 QnA사이트 입니다. 작성한 답변에 다른 개발자들이 댓글을 작성하거나 좋아요/싫어요를 할 수 있기 때문에 계정을 필요로 합니다.
► 로그인
► 계정만들기
Close