* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Window10 64bit | |
CUBRID 10.1.2.7694 | |
[도움말]-[버전정보] 확인 | |
java |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
기존 오라클에서 CUBRID로 DB를 이관 중 이전 오라클 쿼리중
SELECT COM.COMMENTS
, SUBSTR(com.TABLE_NAME,INSTR(com.TABLE_NAME,'_',1,1)+1, INSTR(com.TABLE_NAME,'_',1,2)-(INSTR(com.TABLE_NAME,'_',1,1)+1)) AS MESSAGE_CD
, com.TABLE_NAME
, TO_NUMBER( DBMS_XMLGEN.GETXMLTYPE('SELECT COUNT(*) FROM testmgr.' || com.TABLE_NAME || ' WHERE DEAL_STAT in ( ''Y'', ''E'' ) AND substr(DATEANDTIME,0,8) = ''' || :todate || ''' ' ).EXTRACT('//text()')) AS TOT_CNT
, TO_NUMBER( DBMS_XMLGEN.GETXMLTYPE('SELECT COUNT(*) FROM testmgr.' || com.TABLE_NAME || ' WHERE DEAL_STAT=''Y'' AND substr(DATEANDTIME,0,8) = ''' || :todate || ''' ' ).EXTRACT('//text()')) AS USE_CNT
, TO_NUMBER( DBMS_XMLGEN.GETXMLTYPE('SELECT COUNT(*) FROM testmgr.' || com.TABLE_NAME || ' WHERE DEAL_STAT=''E'' AND substr(DATEANDTIME,0,8) = ''' || :todate || ''' ' ).EXTRACT('//text()')) AS ERR_CNT
, '' AS TODATE
FROM all_tables TAB , ALL_TAB_COMMENTS COM, all_views VIW
WHERE TAB.TABLE_NAME(+) = COM.TABLE_NAME
AND viw.view_name(+)=com.table_name
AND com.owner = 'TESTMGR'
AND com.table_name LIKE 'OOO%'
전체 테이블에서 특정 수신현황을 날짜(todate)를 조건으로 카운트하는 쿼리가 있습니다. all_tables나 all_tab_comment는 어떻게 변경해서 쓰겠는데 DBMS_XMLGEN.GETXMLTYPE
이 쿼리는 CUBRID 형태로 바꿔서 쓸수 있는지 아니면 다른 방식이 있는지 문의드립니다.
DBMS_XMLGEN.GETXMLTYPE().EXTRACT('//text()') 함수 내에 있는 질의문을 Java Stored Procedure로 작성하여 호출하는 형태로 가져가야할 것 같습니다.
select절에 사용하는 DBMS_XMLGEN 내에 있는 쿼리문을 java stored procedure 작성 해주시면 가능 할 것 같습니다.
sp_tot_cnt('각각의 테이블', 'todate') as tot_cnt, , sp_use_cnt('각각의 테이블', 'todate') as use_cnt, sp_err_cnt('각각의 테이블', 'todate') as err_cnt
참조사항
1) 자바가 설치 되어 있어야 합니다.
2) 환경 설정(cubrid.conf)에 java_stored_procedure=yes로 설정 해야 합니다.
https://www.cubrid.org/manual/ko/9.3.0/sql/jsp.html