Background Image
조회 수 1304 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

CUBRID에서 정규표현식을  사용하기 위해서 REGEX 기능을 제공한다.

해당 식의 결과 값은 1 또는 0 으로 일치 또는 불일치로 표현된다.


자세한 내용은 다음의 링크를 참고 : https://www.cubrid.org/manual/ko/9.3.0/sql/function/condition_fn.html?highlight=regex#regexp-rlike


패턴이 일치하고 불일치하는지 찾아 낼수는 있으나 해당 패턴을 이용해서 치환을 하기에는 어렵다.


CUBRID에서는 Java SP(Function/Stored Procedure)기능이 있으므로 해당 기능을 활용해서 치환하는 펑션을 생성 하도록 하겠다.


일단 Java Funcation 용 간단한 java 를 짜서 컴파일한다.


클래스명은 RegexLib 로 만들고 메소드명은 ReplaceAll이라고 만든다.


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;
    }
}


해당 코드를 컴파일 한다음 loadjava 유틸리티를 이용해서 필요한 데이터베이스에 class 파일을 load 후 사용하면 된다.


$ loadjava 데이터베이스명 RegexLib.class 


이제 해당 class를 Function으로 등록 해 보자. csql 또는 CM(cubrid manger)로 해당 데이터베이스에 접속한 후

CREATE FUNCTION RegexReplaceAll(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';


RegexReplaceAll(원문, 패턴, 패턴치환문자열) 로 만들었다.

 

이제 테스트를 해 보자.

csql> create table tst(a varchar(200));

Execute OK. (0.071368 sec) Committed.


1 command(s) successfully processed.

csql> insert into tst values

csql> ('2015 특수교육대상학생의 사회과 교수.학습 지도'),

csql> ('2015 특수교육대상학생의 과학과 교수.학습지도'),

csql> ('2015 장애학생 이해와 통합학급 운영'),

csql> ('2015 치료교육 표시과목 변경 직무연수'),

csql> ('2015 특수교육교원 역량강화'),

csql> ('2015 장애학생 진로.직업교육'),

csql> ('미래를 열어주는 장애학생의 진로_직업교육(전문과정)'),

csql> ('2014-장애학생 이해와 통합학급 운영2'),

csql> ('2014-장애학생 이해와 통합학급운영'),

csql> ('2014-특수교육대상학생의 국어과 교수 · 학습지도')

csql> ;

10 rows affected. (0.000916 sec) Committed.

csql> select RegexReplaceAll(a, '^[[0-9년_-]|[ ]]+', '') from tst;

=== <Result of SELECT Command in Line 1> ===

  RegexReplaceAll(a, '^[[0-9년_-]|[ ]]+', '')
======================
  '특수교육대상학생의 사회과 교수.학습 지도'
  '특수교육대상학생의 과학과 교수.학습지도'
  '장애학생 이해와 통합학급 운영'
  '치료교육 표시과목 변경 직무연수'
  '특수교육교원 역량강화'
  '장애학생 진로.직업교육'
  '미래를 열어주는 장애학생의 진로_직업교육(전문과정)'
  '장애학생 이해와 통합학급 운영2'
  '장애학생 이해와 통합학급운영'
  '특수교육대상학생의 국어과 교수 · 학습지도'

10 rows selected. (0.011080 sec) Committed.


해당 기능이 잘 동작함이 확인 되었다.


이처럼 CUBRID에서는 Java Sp를 이용하면 Java로 구현가능한 대부분을 만들 수 있다.


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
24 기타 Oracle import 시 character set 변경관련 김창휘 2016.12.26 8609
23 기타 JBoss 사용 시 statement pooling 설정 손승일 2016.12.16 2903
22 기타 Tomcat's JDBC Pool 사용 시 JNDI DataSource 설정 손승일 2016.12.16 6436
21 기타 CUBRID HA에서 사용하는 포트 확인 방법(1523, 59901) 주현 2015.07.01 8153
20 기타 전자정부 표준프레임워크 CUBRID 사용 방법 문의 참조 cubebridge 2012.09.17 20588
19 기타 CUBRID csql -i 옵션 사용시 주의 사항 이용미 2011.12.22 9173
18 기타 테이블에 comment 사용하기 1 남재우 2010.01.01 21050
17 기타 glo 사용시 loaddb 주의 사항 웁쓰 2009.12.31 18650
16 기타 EVALUATE method 수행시 주의해야 할 점 웁쓰 2009.12.31 12875
15 기타 CUBRID 설치 서버의 OS bit 확인하는 방법과 CUBRID bit 확인 방법. file seongjoon 2009.12.15 18961
14 기타 좀비 프로세스 일괄 삭제하기 janus 2009.12.12 32051
13 기타 CUBRID의OLE DB 드라이버 설치 방법. file seongjoon 2009.08.24 16262
12 기타 CUBRID JDBC Driver 빌드 방법 웁쓰 2009.07.01 16941
11 기타 OS별 CPU, memory, kernel bit 를 확인하는 방법입니다. 남재우 2009.06.30 26902
10 기타 ODBC 드라이버만 따로 배포하는 방법 1 file 손승일 2009.06.26 18059
9 기타 조건절에 상수가 아닌 ? 가 있는 질의 플랜보는 방법 손승일 2009.05.28 17564
8 기타 windows vista 환경의 csql에서 ;edit 실행시 오류발생하는 경우 file 손승일 2009.05.27 16686
7 기타 csql에서 Java SP를 이용 조회 시 한글 깨짐현상 조치방법 cubebridge 2009.05.21 21043
6 기타 cubrid: error while loading shared libraries 에러가 발생했을 경우 대처 웁쓰 2009.05.19 22434
5 기타 windows에서의 Build 오류 발생 시 조치방법 cubebridge 2009.05.19 14254
Board Pagination Prev 1 2 Next
/ 2

Contact Cubrid

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