메뉴 건너뛰기

조회 수 9087 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

직원명을 초성으로 검색할수 있도록 요청이 들어와서 
급하게 만들었다.

직원수가 아주많은곳에서는 where절에 사용하면 안됨...

예) fn_korinitialkeyword('홍길동')
return : ㅎㄱㄷ

select *
from 테이블
where fn_korinitialkeyword(직원명컬럼) like '%ㅎㄱㄷ%'

 function fn_korinitialkeyword( str in varchar2) return varchar2
is
   returnStr varchar2(100);  
   cnt number := 0;  
   tmpStr varchar2(10);
begin  
      if str is null then
      return '';
      end if;  
      
      cnt := length(str);  

      for i in 1 .. cnt 
      loop
        tmpStr := substr(str,i,1);
                 
      returnStr := returnStr ||
      case when tmpStr < 'ㄱ' then substr(tmpStr, 11)
            when ascii('ㄱ') <= ascii(tmpStr) and ascii(tmpStr) <= ascii('ㅎ'then chr(ascii(tmpStr))
            when tmpStr < '나' then 'ㄱ'
            when tmpStr < '다' then 'ㄴ'
            when tmpStr < '라' then 'ㄷ'
            when tmpStr < '마' then 'ㄹ'
            when tmpStr < '바' then 'ㅁ'
            when tmpStr < '사' then 'ㅂ'
            when tmpStr < '아' then 'ㅅ'
            when tmpStr < '자' then 'ㅇ'
            when tmpStr < '차' then 'ㅈ'
            when tmpStr < '카' then 'ㅊ'
            when tmpStr < '타' then 'ㅋ'
            when tmpStr < '파' then 'ㅌ'
            when tmpStr < '하' then 'ㅍ'
            else 'ㅎ'
      end;  
      end loop; 
      
      return returnStr;
end;

List of Articles
번호 제목 날짜 조회 수
121 오라클 랜덤함수 2018.10.27 2149
120 오라클 10, 16진수(Decimal, Hex) 변환 2018.10.27 4287
119 Oracle Batch Processing 2016.12.08 6822
118 SQL 작성을 위한 25가지 원칙 2016.12.08 6909
117 아카이브 백업 / 복구 2016.09.12 6968
116 DB Link How-To 2016.09.12 7015
115 oracle 에서 Index를 이용해서 즉 힌트와 rownum을 이용하여 게시판 작성하기 2016.12.08 7023
114 오늘을 기준으로 해당주(week)의 모든 일자조회 2016.12.08 7029
113 PK 수정하기 2016.09.12 7069
112 ORA-28001: the password has expired - 추천 실적용 실전 2016.12.08 7079
111 Oracle 저장 프로시저 샘플 2016.08.29 7140
110 제로보드 reg_date 필드 date 형으로 변환하기 2016.09.12 7168
109 오라클 NULL : 값이 존재하지 않는 상태 2017.01.20 7201
108 오라클(PL/SQL) 미리 정의된 예외처리 2016.12.08 7215
107 자동증가 SEQUENCE 생성 2016.09.12 7249
106 오라클 암호를 분실한 경우 접속 방법 2016.09.21 7274
105 Oracle에서 ORA-28000: 계정이 잠금되었습니다. - 해결 방법 file 2016.08.29 7323
104 기간내 모든 날자(일자) 구하기 2016.12.08 7381
103 Create SYNONYM 2016.09.12 7411
102 Oracle에서 사용자가 생성한 모든 Table, View를 삭제하는 쿼리 만들기 file 2016.08.29 7468
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved