Background Image

FORUM

조회 수 2281 추천 수 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

  1. CUBRID 사용자를 위한 DBeaver 도구 출시 안내

    Date2024.04.23 Byadmin Views43
    read more
  2. SQLGate for CUBRID 영구 무료 라이선스 제공

    Date2020.04.09 Byadmin Views4458
    read more
  3. select 시 한글 깨짐 문의 입니다.

    Date2019.02.11 By닐릴리 Views1178
    Read More
  4. loadjava 실행시 에러 발생합니다.

    Date2019.01.31 By지구인다 Views645
    Read More
  5. cubrid.conf 에 'oracle_style_empty_string=yes' 설정 후, 매니저 내 테이블 목록이 시스템 테이블만 보입니다.

    Date2019.01.31 ByshuaiT80 Views277
    Read More
  6. 큐브리드 마이그레이션툴 사용시 권한질문입니다.

    Date2019.01.31 Bybjosbkjx Views208
    Read More
  7. 다중 REPLACE에 관한 질문입니다

    Date2019.01.30 By위니텍 Views2281
    Read More
  8. 다중 REPLACE에 관한 질문입니다

    Date2019.01.30 By위니텍 Views1312
    Read More
  9. 큐브리드 마이그레이션툴 사용시 질문입니다.

    Date2019.01.28 Bybjosbkjx Views265
    Read More
  10. 보호된 메모리를 읽거나 쓰려고 했습니다....

    Date2019.01.28 By모비23 Views1189
    Read More
  11. insert 관련 문의 드립니다.

    Date2019.01.28 By화니 Views115
    Read More
  12. 전체테이블

    Date2019.01.28 By삐삐 Views115
    Read More
  13. iferror 함수

    Date2019.01.18 By아영이 Views5818
    Read More
  14. 현재 디비가 조회가 되지 않을정도로 느립니다.

    Date2019.01.17 By시리 Views247
    Read More
  15. Oracle XMLAGG 함수의 유사 기능 질문드립니다.

    Date2019.01.14 Byjyheo Views703
    Read More
  16. 실행계획이 달라지는 경우에 대해서 문의드립니다.

    Date2019.01.13 By동건 Views571
    Read More
  17. cubrid 의 데이터베이스 폴더 하위의 lob 폴더 내의 파일들의 정체는?

    Date2019.01.09 By예림이아빠 Views451
    Read More
  18. SAP Connection 관련 질문입니다.

    Date2019.01.09 Bychuci Views195
    Read More
  19. JDBC 드라이버 문제

    Date2019.01.08 By황식이 Views683
    Read More
  20. Ado.net. ExecuteNonQuery의 반환값이 항상 0 입니다.

    Date2019.01.08 By모비23 Views1479
    Read More
  21. Windows 10 에서 CUBRIDManager-10.1.0.0005-windows-x64와 CUBRID-Windows-x64-10.1-latest 설치후 매니저 실행하고 연결이름을 test 입력시 연결오류발생

    Date2019.01.03 Bysimon Views356
    Read More
  22. java 저장 함수에서

    Date2018.12.27 Byklee Views327
    Read More
Board Pagination Prev 1 ... 49 50 51 52 53 54 55 56 57 58 ... 200 Next
/ 200

Contact Cubrid

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