>  기사  >  데이터 베이스  >  준비된 문에서 자동 증가 ID를 검색하는 방법은 무엇입니까?

준비된 문에서 자동 증가 ID를 검색하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-19 21:04:02466검색

How to Retrieve Autoincrement ID from Prepared Statements?

Prepared 문에서 자동 증가 ID 검색

Prepared 문을 사용하여 쿼리를 실행할 때 새로 삽입된 행과 연결된 자동 생성 ID를 검색하는 것이 바람직할 수 있습니다. 이는 준비된 문을 사용하여 가능하지만 기존 접근 방식에 약간의 수정이 필요합니다.

기존 방법에서는 AutoGeneratedKeys 상수가 State 개체의 ExecuteUpdate() 메서드와 함께 사용됩니다. 그러나 이 접근 방식은 준비된 문에는 적용되지 않습니다. 대신 다음 단계를 수행할 수 있습니다.

  1. PrepareStatement() 메서드의 두 번째 매개 변수로 Selection.RETURN_GENERATED_KEYS 플래그를 지정하세요. 이는 쿼리가 자동 생성 키를 생성한다는 것을 데이터베이스에 알립니다.
  2. 평상시처럼 ExecuteUpdate() 메소드를 사용하여 준비된 명령문을 실행합니다.
  3. 의 getGeneratedKeys() 메소드를 사용하여 생성된 키를 검색합니다. 준비된 문.
  4. 결과 집합을 반복하고 자동 생성된 ID를 검색합니다.

다음은 이 접근 방식을 보여주는 수정된 코드 조각입니다.

String sql = "INSERT INTO table (column1, column2) values(?, ?)";
stmt = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);

stmt.executeUpdate();
if (returnLastInsertId) {
   ResultSet rs = stmt.getGeneratedKeys();
    rs.next();
   auto_id = rs.getInt(1);
}

이 단계를 수행하면 준비된 문에서 자동 생성된 ID를 성공적으로 검색하여 새로 삽입된 행의 고유 식별자에 액세스할 수 있습니다.

위 내용은 준비된 문에서 자동 증가 ID를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.