메뉴 건너뛰기

조회 수 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 Oracle 11g Client Install 및 외부 클라이언트 도구의 사용 file 2016.12.08 70678
120 linux 오라클 리스너 설정(오라클 원격접속) 2016.09.11 25399
119 Oracle 11g Database에 외부 접속 허용하도록 설정하기 file 2016.12.08 24905
118 오라클 DB 생성 후 설정 Listener.ora & Tnsnames.ora (윈도우) file 2016.12.08 23306
117 숫자 체크 방법 (IS_NUMBER, IS_NUMERIC) file 2016.12.08 23119
116 구분자로 자르기 (Split) file 2016.12.08 20563
115 [Oracle SQL] 여러 행(ROW)을 하나의 컬럼(COLUMN)으로 합치기 (WM_CONCAT) file 2016.12.08 20008
114 오라클 (Oracle) 11g 를 위한 토드(Toad) 무료 버전 다운받기 file 2016.08.30 16019
113 동적쿼리(Dynamic SQL) 사용법 (텍스트 쿼리) file 2016.12.08 15036
112 숫자를 문자로 변환 시 소수점 처리 (TO_CHAR, FM) file 2016.12.08 15026
111 INSTR 문자열의 뒤(마지막)에서 부터 문자 찾기 (right to left, last) file 2016.12.08 14855
110 컬럼의 값 만큼 행(Row)을 늘리기 file 2016.12.08 14092
109 오라클에서 레코드 값이 없을때 2016.12.08 13469
108 데이터의 암호화 및 복호화 file 2016.12.08 13237
107 CLOB TEXT 데이타를 저장하고, 조회하는 예제 2016.12.08 13061
106 여러개(다중) LIKE 검색 방법 (REGEXP_LIKE 함수) file 2016.12.08 12822
105 피봇(Pivot)을 이용하여 행(Row)을 열(Column)로 바꾸기 file 2016.12.08 12673
104 [Oracle] DB Export, Import 방법 2016.12.08 12607
103 오라클 테이블 생성 스크립트 DDL 추출 - 깔끔하게 Table 전부 추출(Export)하기 file 2016.12.08 12514
102 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 12409
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved