Background Image

FORUM

조회 수 2284 추천 수 0 댓글 2
?

단축키

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 디렉토리 압축

-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
REGEXP를 활용하여 사용하는 방법을 알고 싶습니다

예시)
SELECT * FROM TEST_TABLE WHERE TEST = REPLACE(REPLACE(REPLACE(REPLACE(REPLACE('1234567890', '2', ''), '4', ''), '6', ''), '8', ''), '0', '')

1부터 0까지 있는 문자열이 있을때 짝수만 지우고 홀수만 결과값을 얻고 싶을때 어떻게 활용이 가능한지 답변 부탁드립니다
  • ?
    엄기호 2019.01.30 16:54

    큐브리드를 이용해주셔서 감사합니다.

    큐브리드에서 정규식(REGEXP)를 활용하여 사용하는 방법은 URL : https://www.cubrid.org/manual/ko/9.3.0/sql/function/condition_fn.html#regexp-rlike

    예시 질의문 REPLACE함수를 REGEXP함수로 대체할 수는 없습니다.
    만약 REGEXP를 사용하고 싶으면 java stored procedure 사용하시고, java 정규식 표현을 만들어서 DB에 등록한 다음 함수를 호출하여 사용하셔야 원하는 결과를 얻을 수 있습니다.

    java stored procedure를 사용하는 방법은 URL : https://www.cubrid.org/manual/ko/9.3.0/sql/jsp.html

    아래의 절차대로 진행하시면 원하는 결과를 얻을수 있을 겁니다.

    1) cubrid.conf 의 java_stored_procedure=yes

    2) java 사용하기 위해 환경 설정

    3) 자바 소스 작성 및 컴파일 : RegexLib.java
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;

    public class RegexLib {
    public static String ReplaceAll(String p_data, String p_regex, String p_replace) {
    Pattern ptrn = null;
    Matcher mtch = null;
    String rst = null;

    if(p_regex.isEmpty()) {
    ptrn = Pattern.compile("");
    } else {
    ptrn = Pattern.compile(p_regex);
    }


    try {
    mtch = ptrn.matcher(p_data);
    rst = mtch.replaceAll(p_replace);
    } catch (Exception e) {
    return p_data;
    }

    return rst;
    }
    }

    4) java 컴파일
    5) 컴파일된 Java 클래스 로드
    #> loadjava -y db명 RegexLib.class

    6) 로딩한 Java 클래스 등록(DB 접속한 후 등록)
    CREATE FUNCTION Rregexp_replace(p_data varchar, p_regex varchar, p_replace varchar) RETURN VARCHAR
    AS LANGUAGE JAVA
    NAME 'RegexLib.ReplaceAll(java.lang.String, java.lang.String, java.lang.String) return java.lang.String';

    7) DB를 종료 및 재구동(재구동을 해야지만 java 함수를 사용할 수 있습니다.)
    #>cubrid server stop db명
    #>cubrid server start db명


    8) DB접속 후 쿼리문 수행

     SELECT rregexp_replace('12345678890', '[2, 4, 6, 8, 0]', '');

     SELECT * FROM TEST_TABLE WHERE TEST = (SELECT rregexp_replace('12345678890', '[2, 4, 6, 8, 0]', ''))

  • ?
    박세훈 2019.03.07 14:45
    단순히 여러개의 문자열을 대체하려고 한다면 TRANSLATE 함수를 사용하시면 됩니다.

    EX)
    SELECT TRANSLATE('1234567890', '24680', '') FROM db_root

    자세한 내용은 아래 메뉴얼을 참고하세요.
    https://www.cubrid.org/manual/ko/9.3.0/sql/function/string_fn.html#translate

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 105
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4471
3479 큐브리드 매니저에 테이블 목록이 안보입니다. 1 file 배여사남편 2019.03.08 233
3478 큐브리드 매니저에 데이타베이스 복구가 비활성화 되어있습니다 2 초보 2010.02.08 9752
3477 큐브리드 매니저에 관하여 질문드립니다. 3 yodongky 2017.08.25 386
3476 큐브리드 매니저에 ms949 캐릭터셋 추가 8 종이 2010.05.04 14578
3475 큐브리드 매니저로 큐브리드 접속시 에러가 납니다. 1 노멤버 2017.12.19 493
3474 큐브리드 매니저로 접속했을때 DB 볼륨이름/볼륨유형 표시에 대해서 질문 1 file kidless 2020.01.16 214
3473 큐브리드 매니저로 데이터베이스 생성시 문제점 1 델몬트 2015.08.18 8533
3472 큐브리드 매니저로 DB 접속시 오류 1 이쭌 2013.08.27 9356
3471 큐브리드 매니저가 접속이 안됩니다. 1 file 까망이 2014.05.20 5863
3470 큐브리드 매니저가 매우 느립니다. 1 푸품달 2018.11.09 988
3469 큐브리드 매니저가 다운되지 않습니다. 1 퓨전남 2019.07.08 141
3468 큐브리드 매니저, 탭 문자만 선택하고 Ctrl-X 가 동작안하네요 1 안지민 2012.11.20 7987
3467 큐브리드 매니저, 쿼리브라우저 차이점 문의 1 jyuvenia 2011.11.12 13568
3466 큐브리드 매니저(cubrid manager)에서 원격 호스트 접속이 안됩니다. 6 ym 2018.06.11 912
3465 큐브리드 매니저 행 12 file user 2021.12.30 279
3464 큐브리드 매니저 툴(Mac Mojave) 편집 화면에서 쿼리 작성 시 키 타이핑 속도 못따라갈정도로 느린 이슈 2 norman 2019.07.24 389
3463 큐브리드 매니저 테이블 정보 확인 안되는 문제 4 bchlim 2020.09.23 218
3462 큐브리드 매니저 테이블 목록 표시 관련해서 질문이 있습니다 1 리에레이 2023.08.09 91
3461 큐브리드 매니저 테이블 목록 3 응큼한배추 2013.02.05 7305
3460 큐브리드 매니저 클라이언트 연결 오류 문의 3 dus1302 2022.08.29 237
Board Pagination Prev 1 ... 22 23 24 25 26 27 28 29 30 31 ... 200 Next
/ 200

Contact Cubrid

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