필드의 특정값을 가지고있는 게시물만 리스트에 노출하기
여분필드의 특정값을 가지고있는 게시물만 리스트에 노출하기
( 검색시 특정값을 가진 필드만 검색)
사용할일이 있어 팁자료를 확인했는데
https://sir.kr/g5_tip/2147 에 일단 내용이 있는데
제가 만드려는 거랑 좀 안맞아서 수정해 보았습니다.
list.php 파일에
[code]
<?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가
[/code]
1. 하단에 해당 게시판과 원하는 query 값을 넣어 주시고요
[code]
//========================================
$bbs_filter=0;
if($bo_table=="해당게시판"){
if(!$is_admin){
$bbs_filter=1;
$search_str = " 해당컬럼='해당값' ";
}
}
//========================================
[/code]
2. 검색부분에 부분에 || $bbs_fileter 추가
내용안에 if($sca || $stx || $stx) { 검색 부분과
if($bbs_filter){ 부분을 변경
30라인쯤
--> 변경전
[code]
if ($sca || $stx || $stx === '0') { //검색이면
$is_search_bbs = true; //검색구분변수 true 지정
$sql_search = get_sql_search($sca, $sfl, $stx, $sop);
[/code]
--> 변경후
[code]
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} "; }
//====================================
[/code]
3. 이후 하단에 if( $is_search_bbs ) 있는 부분에 ' || $bbs_filter ' 를 적용합니다
181라인쯤
---> 변경전
[code]
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 {
[/code]
---> 변경후
[code]
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 {
[/code]
202라인쯤
---> 변경전
[code]
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']}' ");
[/code]
---> 변경후
[code]
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']}' ");
[/code]
221라인쯤
---> 변경전
[code]
$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\-]*#');
[/code]
---> 변경후
[code]
$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\-]*#');
[/code]
하면 해당 내용을 검색으로 인식하기에
리스트에 글이 많은 사이트에서는 이전 다음 검색을 사용할수 있습니다.
완료 하시고 view.php 에도
<?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가
하단에 아래를 넣어 주시고요
[code]
//========================================
$bbs_filter=0;
if($bo_table=="해당게시판"){
if(!$is_admin){
$bbs_filter=1;
$search_str = " 필드값='해당값' ";
}
}
//========================================
[/code]
이전글 다음글 링크에
15라인쯤
---> 변경전
[code]
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;
}
[/code]
---> 변경후
[code]
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;
}
[/code]
댓글 6개
게시판 목록
그누보드5 팁자료실
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 공지 | 3년 전 | 4427 | ||
| 2694 | 2개월 전 | 197 | ||
| 2693 | 2개월 전 | 155 | ||
| 2692 | 2개월 전 | 163 | ||
| 2691 | 2개월 전 | 178 | ||
| 2690 | 2개월 전 | 330 | ||
| 2689 | 2개월 전 | 241 | ||
| 2688 |
|
2개월 전 | 444 | |
| 2687 | 2개월 전 | 297 | ||
| 2686 |
선택과집중
|
2개월 전 | 334 | |
| 2685 | 2개월 전 | 296 | ||
| 2684 | 2개월 전 | 355 | ||
| 2683 | 3개월 전 | 487 | ||
| 2682 | 3개월 전 | 281 | ||
| 2681 | 3개월 전 | 306 | ||
| 2680 |
선택과집중
|
3개월 전 | 279 | |
| 2679 | 3개월 전 | 334 | ||
| 2678 |
|
3개월 전 | 432 | |
| 2677 |
|
3개월 전 | 505 | |
| 2676 | 3개월 전 | 331 | ||
| 2675 | 3개월 전 | 308 | ||
| 2674 |
선택과집중
|
3개월 전 | 483 | |
| 2673 |
|
3개월 전 | 324 | |
| 2672 | 3개월 전 | 341 | ||
| 2671 | 3개월 전 | 288 | ||
| 2670 | 3개월 전 | 264 | ||
| 2669 | 3개월 전 | 377 | ||
| 2668 | 3개월 전 | 293 | ||
| 2667 |
선택과집중
|
3개월 전 | 489 | |
| 2666 |
선택과집중
|
3개월 전 | 473 | |
| 2665 |
선택과집중
|
3개월 전 | 412 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기