이 글에서는 주로 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
CONCUR_UPDATABLE: ResultSet을 업데이트할 수 있음을 지정합니다
위 내용은 Java의 createStatement() 메소드에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!