공지 |
CUBRID 사용자를 위한 DBeaver 도구 출시 안내
|
admin | 2024.04.23 | 123 |
공지 |
SQLGate for CUBRID 영구 무료 라이선스 제공
|
admin | 2020.04.09 | 4476 |
3882 |
ADO.NET에서 자바 저장함수 호출
2
|
kdknim21 | 2014.11.01 | 8420 |
3881 |
ADO.Net 사용중입니다. 상태확인 방법을 알고 싶습니다.
1
|
CUCUCUCU | 2015.10.22 | 5691 |
3880 |
ADO.net Driver 변경 시 cascci.dll 로드할 수 없다는 오류
1
|
물병 | 2017.07.25 | 503 |
3879 |
ADO.net 또는 ODBC에 대한 질문입니다.
12
|
세스카 | 2012.03.20 | 13378 |
3878 |
ADO이용시 OLEDB Driver에러
2
|
flypig | 2010.01.29 | 15619 |
3877 |
AIX에 CUBRID 설치 후 오류사항 문의
1
|
최명호 | 2015.06.02 | 7736 |
3876 |
ALTER 로 PK 여러 개 지정하고싶습니다
4
|
사탕구름 | 2021.07.21 | 837 |
3875 |
ARRAY 데이터 타입에 대한 SQL 질문
3
|
지용 | 2010.10.08 | 10246 |
3874 |
AUTO INCREASE 가 편집이 안됨
2
|
큐브리드어려워요 | 2022.02.08 | 268 |
3873 |
AUTO_INCREMENT 수동 증가 문의
2
|
cubrid초보 | 2021.08.19 | 728 |
3872 |
AUTO_INCREMENT 컬럼 이용시
2
|
hyperhand | 2009.12.22 | 17649 |
3871 |
AVG 함수관련 질문드려요
1
|
구름마음 | 2013.06.10 | 13678 |
3870 |
Ado.NET : Cannot connect to CUBRID CAS 오류
2
|
websiter | 2017.05.05 | 57912 |
3869 |
Ado.net. ExecuteNonQuery의 반환값이 항상 0 입니다.
2
|
모비23 | 2019.01.08 | 1486 |
3868 |
An IOException was caught during reading the inputstream
1
|
익명2 | 2015.11.26 | 6872 |
3867 |
An IOException was caught during reading the inputstream
1
|
익명2 | 2015.11.26 | 6834 |
3866 |
An IOException was caught during reading the inputstream. 오류 조치방법 좀 알려주세요.
1
|
ldev27 | 2019.10.29 | 316 |
3865 |
An internal error occurred during: "Fetching children of <DB명>". java.lang.NullPointerException 에러
4
|
ysh | 2021.04.06 | 489 |
3864 |
Apm_setup7로 자동설치시 연동이 안되는데...
1
|
또랑 | 2010.11.08 | 8277 |
3863 |
Archive Log만으로 타임복구가 가능한가요?
4
|
핑핑크 | 2016.04.29 | 9821 |
큐브리드를 이용해주셔서 감사합니다.
큐브리드에서 정규식(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]', ''))