필드의 특정값을 가지고있는 게시물만 리스트에 노출하기 > 그누보드5 팁자료실

그누보드5 팁자료실

필드의 특정값을 가지고있는 게시물만 리스트에 노출하기 정보

필드의 특정값을 가지고있는 게시물만 리스트에 노출하기

본문

여분필드의 특정값을 가지고있는 게시물만 리스트에 노출하기

( 검색시 특정값을 가진 필드만 검색)

 

사용할일이 있어 팁자료를 확인했는데  
https://sir.kr/g5_tip/2147 에 일단 내용이 있는데 
제가 만드려는 거랑 좀 안맞아서 수정해 보았습니다.

list.php 파일에 


<?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가

1. 하단에 해당 게시판과 원하는 query 값을 넣어 주시고요  


//========================================
$bbs_filter=0;
if($bo_table=="해당게시판"){
    if(!$is_admin){
        $bbs_filter=1;
        $search_str = " 해당컬럼='해당값' "; 
    }
}
//========================================

2. 검색부분에  부분에 || $bbs_fileter 추가
내용안에 if($sca || $stx || $stx) { 검색 부분과 
if($bbs_filter){ 부분을 변경 

30라인쯤 
--> 변경전

if ($sca || $stx || $stx === '0') {     //검색이면
    $is_search_bbs = true;      //검색구분변수 true 지정
    $sql_search = get_sql_search($sca, $sfl, $stx, $sop);
--> 변경후

if ($sca || $stx || $stx === '0' ||$bbs_filter) {     //검색이면
    if($sca || $stx || $stx){
        $is_search_bbs = true;      //검색구분변수 true 지정
        $sql_search = get_sql_search($sca, $sfl, $stx, $sop);
    }
    //====================================
    if($bbs_filter){     $sql_search .= (($sql_search)?" AND ":"")." {$search_str} ";   }
    //====================================


3. 이후 하단에 if( $is_search_bbs ) 있는 부분에 ' || $bbs_filter ' 를 적용합니다 

181라인쯤 

---> 변경전

if ($sst) {
    $sql_order = " order by {$sst} {$sod} ";
}
if ($is_search_bbs ) {
    $sql = " select distinct wr_parent from {$write_table} where {$sql_search} {$sql_order} limit {$from_record}, $page_rows ";
} else {
---> 변경후

if ($sst) {
    $sql_order = " order by {$sst} {$sod} ";
}
if ($is_search_bbs  || $bbs_filter) {
    $sql = " select distinct wr_parent from {$write_table} where {$sql_search} {$sql_order} limit {$from_record}, $page_rows ";
} else {

202라인쯤 
---> 변경전

while ($row = sql_fetch_array($result))
    {
        // 검색일 경우 wr_id만 얻었으므로 다시 한행을 얻는다
        if ($is_search_bbs)
            $row = sql_fetch(" select * from {$write_table} where wr_id = '{$row['wr_parent']}' ");

---> 변경후

while ($row = sql_fetch_array($result))
    {
        // 검색일 경우 wr_id만 얻었으므로 다시 한행을 얻는다
        if ($is_search_bbs || $bbs_filter)
            $row = sql_fetch(" select * from {$write_table} where wr_id = '{$row['wr_parent']}' ");


221라인쯤 

---> 변경전

$list_href = '';
$prev_part_href = '';
$next_part_href = '';
if ($is_search_bbs) {
    $list_href = './board.php?bo_table='.$bo_table;
    $patterns = array('#&page=[0-9]*#', '#&spt=[0-9\-]*#');

---> 변경후

$list_href = '';
$prev_part_href = '';
$next_part_href = '';
if ($is_search_bbs|| $bbs_filter) {
    $list_href = './board.php?bo_table='.$bo_table;
    $patterns = array('#&page=[0-9]*#', '#&spt=[0-9\-]*#');

하면 해당 내용을 검색으로 인식하기에
리스트에 글이 많은 사이트에서는 이전 다음 검색을 사용할수 있습니다. 

완료 하시고 view.php 에도

<?php

if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가

하단에 아래를 넣어 주시고요 

//========================================
$bbs_filter=0;
if($bo_table=="해당게시판"){
    if(!$is_admin){
        $bbs_filter=1;
        $search_str = " 필드값='해당값' "; 
    }
}
//========================================


이전글 다음글 링크에 


15라인쯤 
---> 변경전

if ($sca || $stx || $stx === '0') {
    // where 문을 얻음
    $sql_search = get_sql_search($sca, $sfl, $stx, $sop);
    $search_href = './board.php?bo_table='.$bo_table.'&page='.$page.$qstr;
    $list_href = './board.php?bo_table='.$bo_table;
} else {
    $search_href = '';
    $list_href = './board.php?bo_table='.$bo_table.'&page='.$page;
}
---> 변경후

if ($sca || $stx || $stx === '0' ||$bbs_filter) {     //검색이면
    if ($sca || $stx || $stx === '0') {
        $sql_search = get_sql_search($sca, $sfl, $stx, $sop);
    }
    //====================================
    if($bbs_filter){  $sql_search .= (($sql_search)?" AND ":"")." {$search_str} ";   }
    //====================================
    $search_href = './board.php?bo_table='.$bo_table.'&page='.$page.$qstr;
    $list_href = './board.php?bo_table='.$bo_table;
} else {
    $search_href = '';
    $list_href = './board.php?bo_table='.$bo_table.'&page='.$page;
}
추천
6

댓글 6개

전체 2,411 |RSS
그누보드5 팁자료실 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT