큐브리드 createStatement 질문드려요

by 차솨 posted Oct 19, 2022


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Window10 64bit
CUBRID Ver.
cubrid11.0
CUBRID TOOL Ver.
cubrid 11.0
응용 환경(API)
java, php, odbc 등 입력


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
 

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class Cubrid_test
{

    public static void main(String[] args)
    {
         Connection con = null;
        try {
            Class.forName("cubrid.jdbc.driver.CUBRIDDriver");
            System.out.println("111");
          con = DriverManager.getConnection("jdbc:cubrid:127.0.0.1:30000:testdb:dba:admin:?charset=utf8");
          
          Statement sta = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
              ResultSet.CONCUR_UPDATABLE,
              ResultSet.HOLD_CURSORS_OVER_COMMIT);
          System.out.println("222");
          
          ResultSet res = sta.executeQuery("SELECT * FROM fi_transorg");

          if (res.getConcurrency() == ResultSet.CONCUR_READ_ONLY) {
              System.out.println("ResultSet non-updatable.");
          } else {
            System.out.println("ResultSet updatable.");
          }

          res.moveToInsertRow();
          System.out.println("333");
          
          res.updateString("emg_report_no", "1");
          res.updateString("trans_ord", "2");
          System.out.println(res.getRow());
          
          res.insertRow();
          res.moveToCurrentRow();
          System.out.println("Row inserted ok.");

    // Close ResultSet and Statement
          res.close();
          sta.close();

          con.close();
        } catch (Exception e) {
          System.err.println("Exception: "+e.getMessage());
          e.printStackTrace();
        }

    }

}
 

이런식으로 큐브리드에 데이터를 넣으려고 하는데 

111
222
ResultSet non-updatable.
333
0
Exception: Insertion query failed.
cubrid.jdbc.driver.CUBRIDException: Insertion query failed.
    at cubrid.jdbc.driver.CUBRIDConnection.createCUBRIDException(CUBRIDConnection.java:951)
    at cubrid.jdbc.driver.CUBRIDResultSet.insertRow(CUBRIDResultSet.java:1417)
    at Cubrid_test.main(Cubrid_test.java:39)
 

이런 오류가 발생합니다.

res.getRow()가 무슨짓을해도 0을 가져오네요..

제 로컬에 데이터 삽입하려는데 해당 createStatement 부분이 잘못되었나요?

 

자바 jdk는 jdk1.8.0_201를 쓰고있습니다.

 


Articles

14 15 16 17 18 19 20 21 22 23