Java
2009.12.30 02:50

SELECT ~ FOR UPDATE 대체 방법

조회 수 34109 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

소개: DBMS에서 SELECT 문을 통해 row level lock을 거는 방법으로 사용되는 SELECT ~ FOR UPDATE 구문이 CUBRID에는 존재하지 않는다. 이를 대체하는 방법으로 CUBRID 확장 JDBC APIsetWriteLock를 소개한다.

적용 대상: CUBRID2008R1.x 이상, JDK1.5이상

 

SELECT ~ FOR UPDATE 대체 방법

DBMS에서 SELECT 문을 통해 특정 row lock을 거는 문장으로 사용되는 것이 SELECT ~ FOR UPDATE 구문이다. 사용 예는 아래와 같다.

SELECT * FROM code where s_name=’X’ FOR UPDATE;

CUBRID에서는 위 구문을 지원하지 않는다. 이를 대체하기 위해서 CUBRID 확장 JDBC API setWriteLock를 제공하고 있다.

구문은

void setWriteLock()

CUBRIDOID 클래스에 포함된 메소드 이다.

setWriteLock 예제

아래는 setWriteLock을 사용하는 예제로 code 테이블의 s_name‘X’ row를 조회하면서 쓰기 잠금을 설정한 후 해당 row f_name‘XXX’ update 시키는 예제이다.

import java.sql.*;

import cubrid.sql.*;              //1

public class TestWriteLock1{

  public static void main(String arg[]) throws Exception {

    Connection conn = null;

    PreparedStatement  ps = null;

    ResultSet rs = null;

    try {

      Class.forName("cubrid.jdbc.driver.CUBRIDDriver");

      conn = DriverManager.getConnection("jdbc:cubrid:localhost:39000:demodb:::","","");

      conn.setAutoCommit(false);          //2

      Object result = null;

      String sbQuery = "SELECT class(a), a.* FROM code a WHERE a.s_name=?";                            //3

      String s_name = "X";

      String f_name = "XXX";

      ps = conn.prepareStatement(sbQuery);

      ps.setString(1, s_name);

      rs = ps.executeQuery();

      if(rs.next()) {

        result = rs.getObject(1);             //4

        CUBRIDOID oid = (CUBRIDOID)result;          //5

        oid.setWriteLock();     //6

        if(ps != null) ps.close();

        ps = conn.prepareStatement("UPDATE code SET f_name = ? WHERE CLASS(code) = ?");         //7

        ps.setString(1, f_name);

        ps.setObject(2, result);               //8

        ps.executeUpdate();

      }

      if(rs != null) rs.close();

      if(ps != null) ps.close();

      conn.commit();

    }catch ( SQLException e ) {

      conn.rollback();

      e.printStackTrace();

    } catch(Exception e) {

      conn.rollback();

      e.printStackTrace();

    } finally {

      if(rs != null) rs.close();

      if(ps != null) ps.close();

      if(conn != null) conn.close();

    }

  }

}

·      1 : setWriteLock CUBRIDOID의 메소드로 CUBRIDOID를 사용하기 위해서는 cubrid.sql.* import 해야한다.

·      2 : 동일 트랜잭션 내에서 select update를 수행하여야 하므로 autoCommit false로 설정한다.

·      3 : 해당 row OID를 가져오기 위해서는 SELECT 문에 class(table_name) 형식으로 명시해준다. 위 예제는 code 테이블의 alias a로 부여 하였기 때문에 class(a)와 같이 명시 하였다.

·      4, 5 : 조회된 OID getObject() 를 사용하여 Object 형태로 받은 후, CUBRIDOID로 형변환을 수행한다.

·      6 : CUBRIDOID.setWriteLock()를 호출하여 해당 row를 쓰기 잠금 설정한다.

·      7 : 쓰기 잠금 설정된 row의 데이터를 update하기 위해서 비교 조건으로 위에서 받아온 OID를 사용한다. OID를 조회 조건으로 사용하기 위해서는 class(table_name) 형식으로 명시해준다.

·      8 : OID 값을 해당 위치에 바인딩 하기 위해서는 setObject()를 사용한다.

 


  1. CUBRID 복제 구성하기 - 단일 서버에 구성 방법 포함

    Date2010.03.08 Category기타 By남재우 Views32685
    Read More
  2. CUBRID 2008 주요 명령어

    Date2008.11.21 Category기타 Byadmin Views32693
    Read More
  3. CUBRID 설치 및 매니저 구동하기(CUBRID 2008 R1.x)

    Date2009.07.18 CategoryInstall ByCUBRID_DEV Views32830
    Read More
  4. CUBRID 2008 을 하나의 머신에 여러번 설치하기(multi instance)

    Date2008.11.21 CategoryInstall Byadmin Views33020
    Read More
  5. CUBRID 매니저 R3.1에서 웹호스팅 서버의 CUBRID R2.1 접속하는 방법 (큐브리드 매니저에서 다른 버전의 큐브리드 서버 접속 방법)

    Date2011.07.14 Category기타 Byadmin Views33226
    Read More
  6. CUBRID기반으로 XE 운영하기 – 설치가이드

    Date2012.04.13 CategoryInstall Bycubebridge Views33231
    Read More
  7. CUBRID Migration Toolkit 튜토리얼

    Date2010.10.22 Category기타 Bycubrid Views33559
    Read More
  8. MySQL,PHP 기반에서 CUBRID,PHP 기반으로 포팅하기

    Date2009.07.02 CategoryPHP By시난 Views33689
    Read More
  9. SELECT ~ FOR UPDATE 대체 방법

    Date2009.12.30 CategoryJava By손승일 Views34109
    Read More
  10. 대량의 데이터 입력 방법

    Date2008.11.21 Category기타 Byadmin Views34383
    Read More
  11. cron을 이용한 백업 자동화

    Date2009.04.01 CategoryLinux Byadmin Views34403
    Read More
  12. CUBRID 데이터베이스와 연동하여 Qt어플리케이션 개발하기 - 1

    Date2010.01.14 Category기타 By김대진 Views34518
    Read More
  13. 제로보드 XE 사용하기

    Date2008.11.21 Category기타 Byadmin Views34964
    Read More
  14. SQuirreL SQL Client에서 CUBRID 사용하기

    Date2009.04.18 CategoryJava ByPrototype Views36079
    Read More
  15. CUBRID 2008 + XE 설치 가이드 [R1.x]

    Date2009.03.13 Category기타 ByPrototype Views36219
    Read More
  16. CUBRID 관련 유용한 기술 자료...

    Date2010.02.19 Category기타 By정병주 Views36561
    Read More
  17. CUBRID와 타 데이터베이스 기능 비교

    Date2008.11.21 Category기타 Byadmin Views38029
    Read More
  18. CUBRID 2008 사용법

    Date2008.11.21 CategoryLinux Byadmin Views38144
    Read More
  19. log4jdbc를 사용한 JDBC 로그 분석

    Date2009.07.02 CategoryJava By시난 Views38373
    Read More
  20. LINUX에서 PHP 사용하기 - phpize를 이용한 설치

    Date2008.11.21 CategoryPHP Byadmin Views38823
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

Contact Cubrid

영업문의 070-4077-2112 / 기술문의 070-4077-2148 / 대표전화 070-4077-2110 / Email. contact_at_cubrid.com
Contact Sales

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

나눔고딕 사이트로 가기

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5