테스트 사이트 - 개발 중인 베타 버전입니다

전체 검색시 게시판의 이름에 공백을 무시하고 검색결과에 가져오는 방법 채택완료

greblue 2년 전 조회 1,987

예를 들어 게시판과 게시물의 이름이 '여름 기본템 반팔티'인데, 전체 검색시에 '여름기본템' 또는 '여름반팔티'로 검색하면 검색결과가 없다고 나옵니다.

 

위의 예시와 같이 게시판이나 게시물 이름/제목에 공백이 있는데, 검색어에는 공백이 없더라도 결과가 보여졌으면 하는데요.

 

고수님들의 답변을 부탁드립니다.ㅜㅜ

댓글을 작성하려면 로그인이 필요합니다.

답변 3개

채택된 답변
+20 포인트

search.php 에 보면 $q 에다가 trim 함수 있어요 이걸 제거 해보세요 주석처리도 좋구요

로그인 후 평가할 수 있습니다

답변에 대한 댓글 3개

g
greblue
2년 전
아래의 코드에서 $q 부분을 찾을수가 없는데, 정확한 위치 좀 알려주시겠어요?


<?php
include_once('./_common.php');

$tmp_gr_id = $gr_id;

if(!$sfl) $sfl = 'wr_subject||wr_content';

// Page ID
$pid = ($pid) ? $pid : 'search';
$at = apms_page_thema($pid);
include_once(G5_LIB_PATH.'/apms.thema.lib.php');

// 스킨 체크
list($search_skin_path, $search_skin_url) = apms_skin_thema('search', $search_skin_path, $search_skin_url);

// 설정값 불러오기
$is_search_sub = false;
@include_once($search_skin_path.'/config.skin.php');

$g5['title'] = '전체검색 결과';

if($is_search_sub) {
include_once(G5_PATH.'/head.sub.php');
if(!USE_G5_THEME) @include_once(THEMA_PATH.'/head.sub.php');
} else {
include_once('./_head.php');
}

$skin_path = $search_skin_path;
$skin_url = $search_skin_url;

$gr_id = $tmp_gr_id;

$bo_list = array();
$search_table = Array();
$table_index = 0;
$write_pages = "";
$text_stx = "";
$srows = 0;

$stx = strip_tags($stx);
//$stx = preg_replace('/[[:punct:]]/u', '', $stx); // 특수문자 제거
$stx = get_search_string($stx); // 특수문자 제거
if ($stx) {
$stx = preg_replace('/\//', '\/', trim($stx));
$sop = strtolower($sop);
if (!$sop || !($sop == 'and' || $sop == 'or')) $sop = 'and'; // 연산자 and , or
$srows = isset($_GET['srows']) ? (int)preg_replace('#[^0-9]#', '', $_GET['srows']) : 10;
if (!$srows) $srows = 10; // 한페이지에 출력하는 검색 행수

$g5_search['tables'] = Array();
$g5_search['read_level'] = Array();
$sql = " select gr_id, bo_table, bo_read_level, as_grade, as_equal, as_min, as_max from {$g5['board_table']} where bo_use_search <> '0' and bo_use_search <= '{$member['mb_level']}' and bo_list_level <= '{$member['mb_level']}' ";
if ($gr_id)
$sql .= " and gr_id = '{$gr_id}' ";
$onetable = isset($onetable) ? $onetable : "";
if ($onetable) // 하나의 게시판만 검색한다면
$sql .= " and bo_table = '{$onetable}' ";
$sql .= " order by bo_order, gr_id, bo_table ";
$result = sql_query($sql);
for ($i=0; $row=sql_fetch_array($result); $i++)
{
if ($is_admin != 'super')
{
// 메뉴접근에 따른 검색차단
if(apms_auth($row['as_grade'], $row['as_equal'], $row['as_min'], $row['as_max'], 1)) {
continue;
}

// 그룹접근 사용에 대한 검색 차단
$sql2 = " select gr_use_access, gr_admin, as_show, as_grade, as_equal, as_min, as_max from {$g5['group_table']} where gr_id = '{$row['gr_id']}' ";
$row2 = sql_fetch($sql2);
// 그룹접근을 사용한다면
if (!$row2['as_show']) {
continue;
} else if (apms_auth($row2['as_grade'], $row2['as_equal'], $row2['as_min'], $row2['as_max'], 1)) {
continue;
} else if ($row2['gr_use_access']) {
// 그룹관리자가 있으며 현재 회원이 그룹관리자라면 통과
if ($row2['gr_admin'] && $row2['gr_admin'] == $member['mb_id']) {
;
} else {
$sql3 = " select count(*) as cnt from {$g5['group_member_table']} where gr_id = '{$row['gr_id']}' and mb_id = '{$member['mb_id']}' and mb_id <> '' ";
$row3 = sql_fetch($sql3);
if (!$row3['cnt'])
continue;
}
}
}
$g5_search['tables'][] = $row['bo_table'];
$g5_search['read_level'][] = $row['bo_read_level'];
}

$op1 = '';

// 검색어를 구분자로 나눈다. 여기서는 공백
$s = explode(' ', strip_tags($stx));

if( count($s) > 1 ){
$s = array_slice($s, 0, 2);
$stx = implode(' ', $s);
}

$text_stx = get_text(stripslashes($stx));

$search_query = 'sfl='.urlencode($sfl).'&amp;stx='.urlencode($stx).'&amp;sop='.$sop;

// 검색필드를 구분자로 나눈다. 여기서는 +
$field = explode('||', trim($sfl));

$str = '(';
for ($i=0; $i<count($s); $i++) {
if (trim($s[$i]) == '') continue;

$search_str = $s[$i];

// 인기검색어
insert_popular($field, $search_str);

$str .= $op1;
$str .= "(";

$op2 = '';
// 필드의 수만큼 다중 필드 검색 가능 (필드1+필드2...)
for ($k=0; $k<count($field); $k++) {
$str .= $op2;
switch ($field[$k]) {
case 'mb_id' :
case 'wr_name' :
$str .= "$field[$k] = '$s[$i]'";
break;
case 'wr_subject' :
case 'wr_content' :
if (preg_match("/[a-zA-Z]/", $search_str))
$str .= "INSTR(LOWER({$field[$k]}), LOWER('{$search_str}'))";
else
$str .= "INSTR({$field[$k]}, '{$search_str}')";
break;
default :
$str .= "1=0"; // 항상 거짓
break;
}
$op2 = " or ";
}
$str .= ")";

$op1 = " {$sop} ";

}
$str .= ")";

$sql_search = $str;

$str_board_list = "";
$board_count = 0;

$time1 = get_microtime();

$z = 0;
$total_count = 0;
for ($i=0; $i<count($g5_search['tables']); $i++) {
$tmp_write_table = $g5['write_prefix'] . $g5_search['tables'][$i];
리오닥터
2년 전
아!! 제가 잘못 전달 했는데 일부 소스코드 보여주시니 도움 되네요

$stx = preg_replace('/\//', '\/', trim($stx)); 이부분에서

$stx = preg_replace('/\//', '\/', $stx);
trim을 빼서 해보세요
g
greblue
2년 전
밑에 알려주신 trim부분 제거해도 안되네요. ㅜㅜ
답변 감사합니다!

댓글을 작성하려면 로그인이 필요합니다.

제목에서 모든 공백을 제거한

문자열을 다른 컬럼에 지정하시고

이 컬럼 대상으로 검색해 보세요.

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

엑스엠엘
2년 전
인덱스는 상황 봐 가면서 추가하시고요.

댓글을 작성하려면 로그인이 필요합니다.

2년 전

mysql REPLACE 를 이용해서 공백을 제거하시면 될거 같습니다.

로그인 후 평가할 수 있습니다

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인