* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Window7 32bit, Linux 64bit 등 | |
[cubrid_rel] 수행 결과 | |
[도움말]-[버전정보] 확인 | |
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까지 있는 문자열이 있을때 짝수만 지우고 홀수만 결과값을 얻고 싶을때 어떻게 활용이 가능한지 답변 부탁드립니다
큐브리드를 이용해주셔서 감사합니다.
큐브리드에서 정규식(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]', ''))