개발자 Q&A

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

2025.06.23 00:07

SQLite3::lastInsertRowID 사용법에 대한 질문

목록
  • 백엔드버서커 2일 전 2025.06.23 00:07
  • 18
    1
제가 SQLite3::lastInsertRowID를 사용하여 마지막으로 삽입한 행의 ID를 가져오려고 하는데, 다음의 코드를 작성하였습니다.

ruby

require 'sqlite3'



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

db.execute('INSERT INTO users (name, email) VALUES (?, ?)', 'john', 'john@example.com')

id = db.last_insert_row_id

puts id



이 코드는 정상적으로 작동하지만, 어떤 경우에 last_insert_row_id가 -1을 반환하는지 알려주실 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    last_insert_row_id는 SQLite3::Database 객체가 마지막으로 실행된 INSERT, UPDATE, REPLACE, DELETE 쿼리의 ROWID를 반환합니다.

    last_insert_row_id가 -1을 반환하는 경우는 다음과 같습니다.

    - 마지막으로 실행된 쿼리가 INSERT, UPDATE, REPLACE, DELETE가 아닌 경우
    - 마지막으로 실행된 쿼리가 ROWID를 사용하지 않는 테이블에 대한 경우
    - 마지막으로 실행된 쿼리가 ROWID를 사용하는 테이블에 대한 UPDATE, REPLACE, DELETE 쿼리인 경우
    - 마지막으로 실행된 쿼리가 트랜잭션 내에서 실행된 경우 (트랜잭션을 커밋하지 않은 경우)

    이러한 경우를 피하기 위해, INSERT 쿼리 이후에 last_insert_row_id를 호출하는 것이 좋습니다.

    또한, SQLite3::Database 객체를 사용할 때는 트랜잭션을 사용하는 경우, 트랜잭션을 커밋한 후에 last_insert_row_id를 호출해야 합니다.

    예를 들어, 다음 코드는 정상적으로 작동합니다.

    ruby
    
    require 'sqlite3'
    
    
    
    db = SQLite3::Database.new('example.db')
    
    db.execute('BEGIN TRANSACTION')
    
    db.execute('INSERT INTO users (name, email) VALUES (?, ?)', 'john', 'john@example.com')
    
    db.execute('COMMIT')
    
    id = db.last_insert_row_id
    
    puts id
    
    


    반면에, 다음 코드는 last_insert_row_id가 -1을 반환합니다.

    ruby
    
    require 'sqlite3'
    
    
    
    db = SQLite3::Database.new('example.db')
    
    db.execute('BEGIN TRANSACTION')
    
    db.execute('INSERT INTO users (name, email) VALUES (?, ?)', 'john', 'john@example.com')
    
    id = db.last_insert_row_id # last_insert_row_id가 -1을 반환합니다.
    
    db.execute('COMMIT')
    
    

    2025-06-23 00:08

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

검색

게시물 검색