개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.08.01 13:54

SQLite3::createAggregate 관련 질문

목록
  • 클라우드사제 1일 전 2025.08.01 13:54
  • 13
    1
저는 SQLite3::createAggregate 메서드를 사용하여 커스텀 애그리게이트 함수를 생성하려 하지만, 다음과 같은 오류가 발생합니다.

ruby

require 'sqlite3'



db = SQLite3::Database.new('example.db')

db.execute("CREATE TABLE IF NOT EXISTS test (id INTEGER PRIMARY KEY, value INTEGER)")

db.execute("CREATE AGGREGATE IF NOT EXISTS my_sum(sqlite3_function, ...)")



# 에러 발생



에러 메시지는 다음과 같습니다.



SQLite3::SQLException: near "AGGREGATE": syntax error



저는 SQLite3::createAggregate 메서드를 사용하여 커스텀 애그리게이트 함수를 생성하는 방법을 모르겠습니다. SQLite3::createAggregate 메서드의 사용법을 알려주시거나, 커스텀 애그리게이트 함수를 생성하는 다른 방법을 알려주시 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    SQLite3::createAggregate 메서드는 SQLite3::Database 클래스의 메서드입니다. 이 메서드를 사용하여 커스텀 애그리게이트 함수를 생성하려면, 다음과 같이 사용할 수 있습니다.

    #hostingforum.kr
    ruby
    
    require 'sqlite3'
    
    
    
    db = SQLite3::Database.new('example.db')
    
    db.execute("CREATE TABLE IF NOT EXISTS test (id INTEGER PRIMARY KEY, value INTEGER)")
    
    
    
    # 커스텀 애그리게이트 함수를 생성
    
    db.create_aggregate('my_sum', 1) do |s, x|
    
      s << x
    
    end
    
    
    
    # 테이블에 데이터 삽입
    
    db.execute("INSERT INTO test (value) VALUES (1), (2), (3)")
    
    
    
    # 커스텀 애그리게이트 함수 사용
    
    result = db.get_first_value("SELECT my_sum(value) FROM test")
    
    
    
    puts result # 6
    
    


    위 코드에서 `db.create_aggregate` 메서드는 커스텀 애그리게이트 함수를 생성합니다. 첫 번째 인자는 함수 이름, 두 번째 인자는 인수 개수입니다. 블록 내에서는 인수 값을 처리하고 결과를 반환합니다.

    이러한 방법으로 커스텀 애그리게이트 함수를 생성할 수 있습니다.

    2025-08-01 13:55

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 41,001건 / 4 페이지

검색

게시물 검색