공지 |
CUBRID 사용자를 위한 DBeaver 도구 출시 안내
|
admin | 2024.04.23 | 48 |
공지 |
SQLGate for CUBRID 영구 무료 라이선스 제공
|
admin | 2020.04.09 | 4458 |
3674 |
CUBRID-11.2.0 에서 CUBRID-11.2.1 patch 를 진행하며 ...
1
|
리들러 | 2022.08.21 | 164 |
3673 |
조건절서브쿼리오류
1
|
ozro | 2022.08.12 | 140 |
3672 |
쿼리 오류 (컬럼 조회 순서에 따라 오류)
7
|
ozro | 2022.08.11 | 204 |
3671 |
11.2 path 방법 문의
4
|
리들러 | 2022.08.09 | 99 |
3670 |
다른 사용자에 생성된 함수 조회
1
|
ozro | 2022.08.05 | 97 |
3669 |
사용자 권한 부여
2
|
ozro | 2022.08.04 | 183 |
3668 |
리눅스 ODBC 문의
4
|
내일은없다 | 2022.08.04 | 69 |
3667 |
큐브리드 마이그레이션 툴 이용중 계속 문제가 발생합니다
6
|
wjdrmstn | 2022.08.04 | 272 |
3666 |
CUBRID 11.2 쿼리 성능 이슈
13
|
tree1891 | 2022.08.02 | 525 |
3665 |
큐브리드 매니저 접속 문제(jdbc 드라이버)
3
|
ozro | 2022.08.01 | 225 |
3664 |
[mac os] cubrid manager 오류 문의
4
|
망고라떼 | 2022.08.01 | 215 |
3663 |
스케줄러 관련 질문
4
|
늅늅 | 2022.08.01 | 233 |
3662 |
JDBC Connection 끊어짐
1
|
steve | 2022.07.21 | 453 |
3661 |
CUBRID 11.2 버전 데이터 이관 문의
2
|
리들러 | 2022.07.19 | 118 |
3660 |
JDBC PreparedStatement excute()에서 오류 발생
3
|
steve | 2022.07.18 | 345 |
3659 |
Error : [-1302] dblink - [HY000][1406][Oracle][ODBC][Ora]ORA-01406 : fetched column value was truncated
15
|
리들러 | 2022.07.13 | 1868 |
3658 |
CUBRID-Windows-x64-11.2-latest, CUBRIDAdmin-11.0-latest-windows-x64 설치후 admin admin 로그인 에러, 로그인하게 해주세요?
4
|
ITPROJECT | 2022.07.11 | 131 |
3657 |
broker가 5개 이상 접속이 되지 않습니다.
2
|
꾸찐 | 2022.07.06 | 212 |
3656 |
Error : [-1302] dblink - Cannot communicate with server[CAS INFO-00.000.00.000:53000, 2, 27657], [CAS INFO-00.000.00.000:30000,7,28322],
4
|
리들러 | 2022.07.06 | 191 |
3655 |
textarea에서 cubrid 입력시 개행처리 문제
1
|
스타일보스 | 2022.07.06 | 77 |
큐브리드를 이용해주셔서 감사합니다.
큐브리드에서 정규식(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]', ''))