개발자 Q&A

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

2025.04.18 21:49

SQLite3::changes 메서드 이해에 필요한 도움이 필요합니다.

목록
  • 네트워크마법사 4일 전 2025.04.18 21:49
  • 54
    1
저는 SQLite3::changes 메서드를 사용하여 데이터베이스에 변경된 행의 수를 확인하고 싶습니다. 하지만, 이 메서드가 반환하는 값의 의미를 이해하지 못하고 있습니다. SQLite3::changes 메서드는 데이터베이스에 변경된 행의 수를 반환하는 것인지, 변경된 쿼리의 수를 반환하는 것인지 알 수 없습니다.

어떻게 SQLite3::changes 메서드가 작동하는지具体한 설명과 예제를 통해 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  4일 전

    SQLite3::changes 메서드는 SQLite3 커넥션의 변경된 행 수를 반환합니다.

    이 메서드는 다음 시점에 호출될 때 변경된 행 수를 반환합니다.

    1. SQL 쿼리가 실행된 후
    2. 커밋 또는 롤백이 수행된 후

    예를 들어, 다음 코드를 실행한 후 SQLite3::changes 메서드를 호출하면 변경된 행 수를 반환합니다.

    #hostingforum.kr
    ruby
    
    require 'sqlite3'
    
    
    
    db = SQLite3::Database.new('example.db')
    
    db.execute('CREATE TABLE users (name TEXT, age INTEGER)')
    
    
    
    # 변경된 행 수는 0입니다.
    
    puts db.changes  # 0
    
    
    
    db.execute('INSERT INTO users (name, age) VALUES ("John", 30)')
    
    db.execute('INSERT INTO users (name, age) VALUES ("Jane", 25)')
    
    
    
    # 변경된 행 수는 2입니다.
    
    puts db.changes  # 2
    
    
    
    db.commit
    
    
    
    # 변경된 행 수는 0입니다.
    
    puts db.changes  # 0
    
    


    이 예제에서 SQLite3::changes 메서드는 SQL 쿼리가 실행된 후 변경된 행 수를 반환합니다. 커밋이 수행된 후 변경된 행 수는 0이 됩니다.

    2025-04-18 21:50

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

검색

게시물 검색