Database/SQL
Oracle 오라클 자음 초성 추출 함수, 자음으로 검색, 초성 검색
리커니
2016. 4. 18. 11:05
반응형
Oracle 오라클 자음 초성 추출 함수, 자음으로 검색, 초성 검색
개발을 하다보면 자음으로만 검색할 수 있게 해달라는 요청이 들어오곤 한다.
그럴때마다 유용하게 사용하는 것이 아래의 함수이다.
그냥 복사 붙여넣고 실행하면 함수가 생성된다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36 |
create or replace function fn_choSearch( 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, 1, 1)
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; |
|
사용방법은 아래와 같다.
필자의 경우 웹페이지의 검색단에서 초성인지 아닌지 아래와 같이 구분을 하여
1
2
3
4
5
6
7
8
9 |
var keyword = $("#keyword").val().toUpperCase();
var choKeyword = choHangul($("#keyword").val());
//초성검색 구분
if (keyword!="" && choKeyword==""){
choDiv = 'Y';
}else{
choDiv = 'N';
} |
cs |
1
2
3
4
5
6
7
8
9
10
11
12 |
/* 초성추출 */
function choHangul(str) {
cho = ["ㄱ","ㄲ","ㄴ","ㄷ","ㄸ","ㄹ","ㅁ","ㅂ","ㅃ","ㅅ","ㅆ","ㅇ","ㅈ","ㅉ","ㅊ","ㅋ","ㅌ","ㅍ","ㅎ"];
result = "";
for(i=0;i<str.length;i++) {
code = str.charCodeAt(i)-44032;
if(code>-1 && code<11172){
result += cho[Math.floor(code/588)];
}
return result;
} |
cs |
sql 조건문에 활용하여 초성검색을 구현하였다.
1
2
3
4
5
6
7
8 |
WHERE 1=1
<isEqual prepend='AND' property="choDiv" compareValue="N" >
S1.STOP_NAME LIKE '%'||#keyword#||'%' OR S1.STOP_ID LIKE '%'||#keyword#||'%'
</isEqual>
<isEqual prepend='AND' property="choDiv" compareValue="Y" >
fn_choSearch(S1.stop_name) LIKE '%'||#keyword#||'%' OR S1.STOP_ID LIKE '%'||#keyword#||'%'
</isEqual> |
cs |
choDiv 값이 N 일 경우 일반검색
choDiv 값이 Y 일 경우 위의 oracle함수를 사용하여 초성검색
예를 들어
이렇게 구현을 하면 'ㄱㄴㄷ' 으로 검색을 하면
가나다
간난단
갇낟닫
...
등 초성이 ㄱ,ㄴ,ㄷ 인 데이터가 검색된다.
Link : Mysql 자음 초성 추출 함수, 자음으로 검색, 초성 검색
반응형