Background Image

FORUM

조회 수 22573 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


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

안녕하세요?


Oracle -> Cubrid 로 전환하려고 하려고 합니다


[문의1]

기존에 사용중인  ORACLE 쿼리문을  cubrid 쿼리로 변환하는 툴이 있다고 기술영업? 관계자분께서 그러신것 같았는데요

마이그레이션 툴로 테이블스키마 이런건 가능한데 쿼리는 어디서 변환하면 되는지 문의 드립니다.


[문의2]

코드명을 조회하기 위해 FUNCTION 을 많이 사용하고 있는데요 이걸 SQL로 풀려니 작업량이 상당해서 문의 드립니다.


SELECT FN_GetUserNm(사원번호) AS USER_NM, FN_GetDeptNm(부서번호) AS DEPT_NM FROM USER_TABLE


사원번호, 부서번호로, 사원명, 부서명을 조회해오는 쿼리입니다. 

이러한 쿼리가 있다라고 가정할 경우  어떻게 변환하는 게 효율적인지 문의 드립니다.


답변 주시면 감사하겠습니다.


  • ?
    손승일 2014.07.02 20:00

    [문의1]

    쿼리 자동 변환 툴은 없습니다.

    직접 변환 작업을 수행하셔야 합니다. 다만 현 응용이 Oracle에서만 지원하는 구문들을 많이 사용하지 않으셨다면 변환에 크게 어려움은 없을 것입니다.


    [문의2]

    Stored Procedure/Function(이하 SP)은 SQL 구문 만으로 처리하기 곤란한 복잡한 로직 처리를 위해 각 DBMS 밴더 별로 확장한 프로그래밍 언어를 사용하고 있습니다.

    현재 사용하고 계시는 Oracle은 PL-SQL이라는 언어로 되어 있구요.

    SP는 해당 DBMS 내에서는 성능, 관리 등의 측면에서 장점이 있지만, 사용자는 표준이 아닌 새로운 언어를 습득해야 하는 어려운 점과 다른 DBMS와 혼환되지 않아 특정 DBMS에 종속되는 단점이 있습니다.

    CUBRID는 오픈소스 DBMS로서 범용성 및 호환성을 위해 SP에 사용할 언어를 표준 범용언어인 JAVA를 채택하고 있습니다.

    아시다시피 JAVA는 JVM이 설치되어 있는 어디서나 실행할 수 있는 장점이 있으나 역으로 보면 꼭 JVM 환경에서만 동작해야 하고 이로 인한 성능 측면에서는 단점이 있습니다.

    CUBRID SP도 JVM 환경에서 실행되고, CUBRID 엔진과 통신하는 구조적 특성 상 실시간으로 return을 요구하는 값이 특정 단일값이 아닌 반복적으로 요구되는 경우 JVM과 CUBRID와 매 건만다 반복 통신을 해야되므로 최적의 성능을 보장할 수 없습니다.

    이러한 이유로 logic을 DBMS가 아닌 응용에서 처리하도록 권장하고 있으며, CUBRID SP는 JAVA로 작성되어 지기때문에 거의 그대로 JAVA 응용에 이식할 수 있습니다.

    그러나, 실시간 응답이 필요없고 SP의 본연의 용도인 로직 구현 용도로 사용하는 batch 작업 등에서는 CUBRID SP를 사용하는 것도 문제 없습니다.

    위 문의하신 경우와 같은 Function의 경우는 outer join이나 scalar sub query를 사용하는 방법으로 우회하는 것이 좋을 것 같습니다.

    예를 들면

    select (select 사원명 from 직원 a where a.사원번호= t.사원번호) as user_nm,

    (select 부서명 from 부서 a where a.부서번호= t.부서번호) as dept_nm from user_table t

    또는

    select a.사원명, b.부서명 from user_table t LEFT OUTER JOIN 직원 a ON a.사원번호= t.사원번호

    LEFT OUTER JOIN 부서 b on a.부서번호= t.부서번호

    두 방식 중 적절한 성능이 나오는 방식을 선택하시는 것이 좋을 것 같습니다.


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4443
947 테이블의 크기 1 카르마 2011.01.10 10880
946 Cubrid Manager 랑 JDBC연결과 cubrid 설치도 문제가있는 것 같습니다. 2 낚시나간지렁이 2014.08.02 10884
945 HA 구성중 서버 이전으로 재구성시 1 라면 2016.07.08 10888
944 큐브리드에 Synonym기능 있나요? 1 김성일컴퍼니 2013.07.18 10889
943 ACTIVE_SESSION 이 48수치에 DB 다운되어 버립니다. 13 안토니오 2010.07.25 10904
942 큐브리드 매니저 connect timed out. 오류 1 아이쿠두야 2012.03.23 10923
941 php 모듈설치가 안되요 5 sapr 2009.11.26 10923
940 큐브리드2008의 DB로드/언로드 기능으로 마이그레이션 방법 문의 12 file 고영진 2009.09.11 10925
939 쿼리 브라우져 가져오기 오류 질문 4 joke7 2013.12.08 10928
938 [질문] APC_Install-tools 1.4 사용시 ~ 2 file 야매코더 2009.03.17 10933
937 updateblob에 대한 문의 입니다. 1 짱똘 2009.10.28 10938
936 MSSQL에서 큐브리드 연동 3 미곰 2016.05.24 10949
935 접속자의 아이피나 맥어드레스를 알아낼수 있는지요 3 유니콘 2012.12.05 10956
934 초보 질문드립니다^^:(인스턴스 갱신) 1 박동진 2009.03.12 10961
933 맥에서 cubrid query browser 실행이 안됩니다. 1 zbqmflem12345 2014.03.29 10964
932 cubridmanager 실행시 오류 입니다. 1 하하보이 2010.12.11 10970
931 원하는 테이블에 데이터를 추가 하고싶으면 어떻게 하나요? 1 나동호 2009.03.25 10981
930 매니저 오류 문의 4 file Kai 2014.01.06 10991
929 오류의 의미?? 10 천상 2016.06.21 10991
928 임시테이블에 대한 지원 계획은 있는지 궁금합니다 2 김종언 2010.07.28 10994
Board Pagination Prev 1 ... 148 149 150 151 152 153 154 155 156 157 ... 200 Next
/ 200

Contact Cubrid

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