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
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 54
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4461
3995 "DATABASE 검사" 도무지 끝날 기미가 안 보입니다 5 한종희 2011.08.02 8583
3994 "DBMS, 0, Unknown DBMS error" 요건 무슨 애러인가요?;; 2 eitetu 2011.06.02 14296
3993 "Token length is too long" 오류에 관하여 질문 드립니다. 4 file 김우람 2009.01.09 21478
3992 & 등의 특수문자등이 변환되어 저장되는 경우 1 호랑이야옹 2012.12.28 10682
3991 ' 의 입력 방식이 궁금합니다. 1 이석희 2009.04.10 13422
3990 (1개의 댓글은 작성자가 썼습니다.)비주얼 베이직 큐브리드 연동후 동시에 여러 테이블 보는 방법문의 2 secret 강남우 2012.12.21 58
3989 (Re:) 회원가입이 3명이상 안돼요... 6 딩이 2010.07.08 7595
3988 (python)centOS7 docker 연결 문의입니다. 리얼비 2021.11.01 108
3987 (댓글 질문등록 했습니다.)이전글, 다음글 기능(LAG, LEAD) ORDER BY절 FOR ORDERBY_NUM() 추가해도 그대로 입니다 3 취우다 2017.04.19 5960
3986 (함수)펑션 오류 확인부탁드립니다. 1 초코초코초 2023.02.10 102
3985 *variable* 에러 1 hwon 2013.06.14 11619
3984 ++ cubrid server start: fail 2 file 토네이도 2013.09.13 13701
3983 -74 오류 조치 방법 1 덜쇠 2013.08.07 7643
3982 .AccessViolationException (C#) 1 swift 2021.06.03 220
3981 .NET 4.5 에서의 NHibernate 문제, .NET 4.0 에서 NHibernate + TransactionScope 활용 문제. 1 websiter 2017.06.09 2057
3980 .NET DB 제어를 위한 방법. 2 우페 2008.11.23 60878
3979 .net db목록 관련 질문 드립니다. 4 파인 2021.03.05 134
3978 // 를 사용하고 싶습니다. 1 죽통군 2010.02.10 9583
3977 /etc/hosts 파일 수정 1 secret chocob 2014.10.13 13
3976 /etc/rc3.d/S98cubrid 화일 좀 바꿔주세요 1 꽁꽁단무지 2017.01.25 12246
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

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