>Java >java지도 시간 >Java의 createStatement() 메소드에 대한 자세한 설명

Java의 createStatement() 메소드에 대한 자세한 설명

怪我咯
怪我咯원래의
2017-06-30 10:30:063575검색

이 글에서는 주로 java의 createStatement() 메소드에 대한 자세한 설명을 소개합니다. 필요하신 분들은 java의 createStatement() 메소드에 대한 자세한 설명을 참고하시면 됩니다.

기본 설정으로 생성되면 ResultSet은 한 번만(일회성) 액세스할 수 있고 전달 전용 및 읽기 전용인 객체

입니다. 데이터에 한 번만 액세스할 수 있습니다. 데이터가 다시 필요한 경우 데이터베이스를 다시 쿼리해야 합니다.

그러나 이것이 유일한 방법은 아닙니다. State 개체에 매개 변수를 설정하면 해당 개체가 생성하는 ResultSet을 제어할 수 있습니다. 예:

...
     Class.forName(driverName);
     db = DriverManager.getConnection(connectURL);
     Statement statement = db.createStatement(
              ResultSet.TYPE_SCROLL_SENSITIVE,
                         ResultSet.CONCUR_UPDATABLE
            );     
     
     String orderElName = xmlfileEl.getElementsByTagName("order").item(0)
                    .getFirstChild().getNodeValue();
...
이 문은 이제 업데이트

할 수 있는 ResultSet을 생성하고 다른 데이터베이스 사용자가 변경한 내용을 적용합니다. 이 ResultSet 내에서 앞뒤로 이동할 수도 있습니다.

첫 번째 매개변수는 ResultSet의 유형을 지정합니다. 옵션은 다음과 같습니다:

TYPE_FORWARD_ONLY: 기본 유형. 정방향 액세스는 한 번만 허용되며 다른 사용자가 데이터베이스를 변경해도 영향을 받지 않습니다.

TYPE_SCROLL_INSENSITIVE: 목록에서 앞이나 뒤로 이동할 수 있으며 목록의 네 번째 레코드로 이동하거나 현재 위치에서 두 개의 레코드를 뒤로 이동하는 등 특정 위치 지정도 허용합니다. 다른 사용자가 데이터베이스를 변경해도 영향을 받지 않습니다.

TYPE_SCROLL_SENSITIVE: TYPE_SCROLL_INSENSITIVE와 마찬가지로 레코드 내 위치 지정을 허용합니다. 이 유형은 다른 사용자가 변경한 내용의 영향을 받습니다. 사용자가 쿼리를 실행한 후 레코드를 삭제하면 해당 레코드는 ResultSet에서 사라집니다. 마찬가지로 데이터 값의 변경 사항은 ResultSet에도 반영됩니다.

두 번째 매개변수는 ResultSet의 동시성을 설정하여 ResultSet을 업데이트할 수 있는지 여부를 결정합니다. 옵션은 다음과 같습니다.
CONCUR_READ_ONLY

: 기본값이며 ResultSet을 업데이트할 수 없음을 지정합니다.

CONCUR_UPDATABLE: ResultSet을 업데이트할 수 있음을 지정합니다

위 내용은 Java의 createStatement() 메소드에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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